Codeforces Round 922 (Div. 2)补题

Brick Wall(Problem - A - Codeforces)

题目大意:规定砖的大小为1*k(k>=2),现在有一面n*m的砖墙,n是墙高,m是墙宽,砖在砖墙中有两种放法,水平放置和竖直放置,墙的稳定性=水平放置的砖的数量-竖直放置的砖的数量。现在要求墙的稳定性的最大值。注意墙不用填满,砖不能相交。

思路:很显然我们尽可能地水平放置,不竖直放置即可。反正又不用填满。

#include<bits/stdc++.h>
using namespace std;
int main()
{
	int t;
	scanf("%d",&t);
	while(t--)
	{
		int n,m;
		scanf("%d%d",&n,&m);
		m /= 2;
		n*=m;
		printf("%d\n",n);
	}
}

Minimize Inversions(Problem - B - Codeforces)

题目大意:现在有两个排列a,b,我们需要选择两个位置i,j,交换ai,aj和bi,bj,最后要使两个序列中的反转数最小。

思路:刚开始我看到这个题也没有什么头绪,然后就去分析了下样例,前两个样例没什么感觉,看到第三个样例的时候,我突然发现第三个样例的输出中第二个排列有序的。呀,昨晚上太着急了,以为它们是有序的,刚刚一看竟然不是,但是最后的结果确实是使一个排序变成有序的。不过我们还是来证明一下比较放心。

我们很容易通过交换使一个排列变成有序的,这样的话,两个排列中的反转数会是最小的吗?显然在有序的那个排列中反转数为0,那么在另一个序列中呢?哎,这个有点证不明白,但是写题解还是不要水,我去看了下官方的证明,思路大概是这样:

对于a,b我们选出来的i,j构成的逆序对数量为0,1,2,如果其中一个排列有序,那么另一个最多是1,这样对于这一对来说就是最优解,让某个序列全部排序,那么每一对都是最优的情况,那么就是最小的时候。

#include<bits/stdc++.h>
using namespace std;
int a[200010],b[200010];
int main()
{
	int t;
	scanf("%d",&t);
	while(t--)
	{
		int n;
		scanf("%d",&n);
		vector<pair<int,int>>p;
		for(int i=1;i<=n;i++) scanf("%d",&a[i]);
		for(int i=1;i<=n;i++) scanf("%d",&b[i]);
		for(int i=1;i<=n;i++) p.push_back({a[i],b[i]});
		sort(p.begin(),p.end());
		for(int i=0;i<n;i++)
		{
			int x=p[i].first,y=p[i].second;
			printf("%d ",x);
		}
		printf("\n");
		for(int i=0;i<n;i++)
		{
			int x=p[i].first,y=p[i].second;
			printf("%d ",y);
		}
		printf("\n");
	}
}

XOR-distance(Problem - C - Codeforces)

题目大意:现有三个数a,b,r,我们需要在[0,r]中选一个数x,使得|(a^x)-(b^x)|最小,输出最小值。

思路:既然涉及到位运算,那么我们就从二进制的角度来看:

显然如果a,b在二进制的某一位相同,那么和x进行异或之后,还是相同的,所以没什么变化,那么我们要想最小化结果,肯定还是要从不同位入手,很明显如果一个为0,一个为1,那么如果是0作为被减数,那么就要从高位退1下来参与,所以我们肯定将最高位1在的那个数中二进制下为1,而另一个数二进制下为0的位置更改一下,另外第一个相异的位置不能改动,因为要从这里退位下来。那么问题就解决了。那么我们直接进行位运算即可,注意不要超过r。

#include<bits/stdc++.h>
using namespace std;
#define int long long
signed main()
{
	int t;
	scanf("%lld",&t);
	while(t--)
	{
		int a,b,r;
		scanf("%lld%lld%lld",&a,&b,&r);
		if(a<b) swap(a,b);
		int flag=1;
		for(int i=60;i>=0;i--)
		{
			int ta=(a>>i)&1,tb=(b>>i)&1;
			if(flag&&ta!=tb) 
			{
				flag=0;
				continue;
			}
			if(!flag)
			{
				if(ta==1&&tb==0) 
				{
					if((1ll<<i)<=r) 
					{
						r -= (1ll<<i);
						a ^= (1ll<<i);
						b ^= (1ll<<i);
					}
				}
			}
		}
		cout<<abs(a-b)<<endl;
	}
}

 Blocking Elements(Problem - D - Codeforces)

题目大意:现在有一个数组a[]和一个数组b[],我们要在a[]中将a[b[i]]的位置挑出来相加,剩下的以被挑走的位置为分隔,划出若干个区间,每个区间内部求和,这些和中的最大值作为结果,输出最小结果。举个例子:

思路:这里的结果肯定是在[1,sum]之内,所以想到二分,要快速求若干区间的和,那么想到预处理前缀和。现在最关键的问题就是二分的check函数怎么写。

我最初想的是就从头开始,一旦超过mid之后就以此划分,最后看挑出来的数是否小于mid,但是显然这个思路不可以。这么来看,我们第一次划分前的所有位置实际都可以作为第一次划分的位置,当然第二,第三次划分也是同理,那么就跟dfs联系起来了,对于搜每一次划分的位置。但是,显然时间复杂度太高了,这个题n的范围还有点大,那么就得换个思路。dfs简化就很容易想到动态规划,那么我们该如何动态规划呢?其实这里已经分析出了一个很重要的条件,每次划分的合法位置是一个区间,那么我们要想使结果最优,肯定是从这个区间中挑比较小的数加进结果。那么可以定义dp[i]表示以i位置为区间结尾,此时被挑选的数的和。因为我们在挑选的时候已经确定了每个区间的和是小于m的,进而来找划分位置,所以只要从这些合法的中找一个最小的即可。从一个区间中找最值,很容易想到滑动窗口,这里又是dp,那么就是单调队列优化dp的类型。还有一个问题,找合法区间的左端点时,是否必须从头开始找,显然不是,因为很容易可以发现,如果当前的i的左端点在j位置,那么后一个i的左端点一定是在j位置后面,因为我们确定区间只是通过区间和小于m来确定的。每一个值都是正数,那么区间和,区间一定不会再变长。所以我们只用看队列的开头是否需要弹出,来找合适的位置,因为队列是单增的,所以开头一定最小。

另外,结尾可能在任意位置,所以我们要循环判断一下。

#include<bits/stdc++.h>
using namespace std;
#define int long long
int q[100010],a[100010],s[100010],dp[100010],hh,tt,n;
int check(int m)
{
	hh=0,tt=1;//数组模拟队列
	q[0]=0;
	for(int i=1;i<=n;i++)
	{
		while(hh<tt&&s[i-1]-s[q[hh]]>m) hh++;
		dp[i]=dp[q[hh]]+a[i];
		while(hh<tt&&dp[q[tt-1]]>=dp[i]) tt--;
		q[tt++]=i;
	}
	for(int i=1;i<=n;i++)
		if(dp[i]<=m&&s[n]-s[i]<=m) return 1;
	return 0;
}
signed main()
{
	int t;
	scanf("%lld",&t);
	while(t--)
	{
		scanf("%lld",&n);
		for(int i=1;i<=n;i++) scanf("%lld",&a[i]),s[i]=s[i-1]+a[i];
		int l=1,r=s[n];
		while(l<r)
		{
			int mid=(l+r)/2;
			if(check(mid)) r=mid;
			else l=mid+1;
		}
		printf("%lld\n",l);
	}
}

核心:虽然这道题既有区间和又有选点,但本质上考的是在限制区间的情况下求最小值,限制区间的条件比较隐蔽而已。 因为每一个划分的合法位置实际在一个区间中找,那么显然要找最小值,那么就是区间找最小值的问题,然后有多个位置,所以联系到单调队列优化的dp问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/361284.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

修复WordPress内部服务器错误的步骤及解决方案

WordPress是一款广泛使用的开源内容管理系统&#xff0c;但在使用过程中&#xff0c;可能会遇到各种内部服务器错误。这些错误可能由于多种原因引起&#xff0c;例如插件冲突、文件权限问题、服务器配置不当等。为了帮助您快速解决这些问题&#xff0c;本文将为您提供一套详细的…

智能优化算法 | Matlab实现霸王龙优化算法(TROA)(内含完整源码)

文章目录 效果一览文章概述源码设计参考资料效果一览 文章概述 智能优化算法 | Matlab实现霸王龙优化算法(TROA)(内含完整源码) 源码设计 %%clear all clcSearchAgents_no=50; % Number of search agentsFunction_name=</

Spring AOP原理的常见面试题

Spring AOP原理的常见面试题 .Spring AOP是怎么实现的什么是代理模式静态代理动态代理怎么实现的JDK动态代理CGLIB动态代理引入依赖 JDK与CJLIB的区别什么时候使用JDK与CJLIB . Spring AOP是怎么实现的 答:Spring AOP是通过动态代理来实现AOP的 什么是代理模式 答:代理模式也…

离线使用Element UI和Vue

需要依赖如下&#xff1a; 1.vue.js; 2.index.js(Element UI) 3.index.css(Element UI) 4.element-icons.ttf(Element UI字体) 5.element-icons.woff(Element UI图标) 下载链接如下&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1nGOi0Vm_xExRGmVp6oVLoA 提取…

Django问题报错:Cannot resolve keyword ‘name‘ into field. Choices are: course, id

笔者在进行登录注册实验用户名已经注册过的操作时报错 一、错误位置 二、问题原因 使用Student模型时参数名错误 三、解决办法 修改为与Student模型中对应的参数名,问题解决

Cache Lab:Part A【模拟出使用LRU策略的高速缓存存储器组织结构】

目录 任务描述 知识回顾 实验内容 测试结果 Cache Lab 对应《CS:APP》6.3节至第六章结束的内容。 任务描述 Your job for Part A is to fill in the csim.c file so that it takes the same command line arguments and produces the identical output as the reference …

0131-2-关于事件捕获和冒泡

关于事件捕获和冒泡 DOM事件流分为三个阶段&#xff1a;捕获阶段、目标阶段、冒泡阶段 点击目标元素后&#xff0c;不会马上触发目标元素&#xff0c;而是先执行事件捕获&#xff0c;从顶部逐步到目标元素&#xff1b;处于目标阶段的时候触发目标元素&#xff1b;最后冒泡阶段…

性能测试工具架构

背景 性能测试工具&#xff08;LoadRunner为例&#xff09; 性能测试工具通常是指那些用来支持压力、负载测试&#xff0c;能够录制和生成脚本、设置和部署场景、产生并发用户和向系统施加持续压力的工具。 性能测试工具录制的是服务端与应用之间的通信数据&#xff0c;而不是…

如何快速知道app当前页面是哪一个Activity(2.0升级版)

点我跳转 如何快速知道app当前页面是哪一个Activity 1.0版本 这个版本是用adb 命令实现的&#xff0c;想看的可以看看&#xff0c;学习一下adb 命令。 今天做了一个非常简易的app来直接监控当前页面Activity&#xff0c;效果直接炸裂&#xff0c;效果图如下&#xff1a; 有需要…

【学习资源】分享一个文献互助平台(CRS核心论文库)

博主在之前的博文中推荐过三个文献互助平台&#xff08;科研通、谷粉、纬度&#xff09;https://blog.csdn.net/dave496206/article/details/135604252?spm1001.2014.3001.5501 博主在这里再补充一个文献互助或下载平台——CRS核心论文库 1、CRS核心论文库首页&#xff1a; …

突破瓶颈!程序员最值得关注的19个顶级油管博主

油管可以说是互联网上最有趣的地方&#xff0c;你可以在这里找到任何你感兴趣的东西。这里也是学习和探索编程世界的绝佳方式。有趣又有才华的技术博主非常多&#xff0c;随时随地都可以与全世界的开发者交流学习。 我们整理了一些在编程领域有影响力的博主&#xff0c;希望能给…

SpringBoot项目logback日志配置

Session 认证和 Token 认证 过滤器和拦截器 SpringBoot统一返回和统一异常处理 SpringBoot项目logback日志配置 程序运行出现错误时&#xff0c;第一时间想到的是甩锅还是日志&#xff1f;通过查看日志定位出问题的位置&#xff0c;才能更好的甩锅&#xff0c;今天就来学习…

配置vite自动按需引入 vant 组件

为什么学 按需加载可以减少包体积,优化加载性能 学习内容 全局注册组件 import 需要的组件import 组件样式使用 app.use 注册组件 Tree Shaking 介绍使用 什么是 tree shaking&#xff1f; Tree shaking是一种优化技术&#xff0c;用于减少JavaScript或其他编程语言中未被使用…

fullcalendar案例

fullcalendar案例 <script srchttps://cdn.jsdelivr.net/npm/fullcalendar6.1.10/index.global.min.js></script><script srchttps://code.jquery.com/jquery-3.6.0.min.js></script> <!-- 引入 jQuery CDN --><script>document.addEventL…

虚拟机VMware vCneter告警:Log DIsk Exhaustion on frvc70,vCenter日志清理

其中frvc70是主机名称 1.告警原因 Troubleshooting vCenter Appliance /storage/log directory is 80% or more ful 当分区/storage/log使用率达到 80% 时&#xff0c;会触发此告警。 2.解决方法 1.通过 SSH 或通过 vCenter 虚拟机控制台连接到 vCenter Server Appliance …

Halcon 几何测量

文章目录 算子Halcon 计算两点之间的距离案例Halcon 计算点到直线的距离Halcon 计算点到区域的距离Halcon 线到区域的距离Halcon 线到线的距离 算子 distance_pp 两点之间的距离算子 distance_pp( : : Row1, Column1, Row2, Column2 : Distance) Row1 点1的行坐标 Column1 点1的…

[ESP32]在Thonny IDE中,如何將MicroPython firmware燒錄到ESP32開發板中?

[ESP32 I MicroPython] Flash Firmware by Thonny(4.1.4) IDE 正常安裝流程&#xff0c;可參考上述影片。然而&#xff0c;本篇文章主要是紀錄安裝過程遇到的bug, 供未來查詢用&#xff0c;也一併供有需要的同好參考。 問題:安裝後&#xff0c;Thonny互動介面顯示一堆亂碼和co…

网安人必看!CISP家族顶流证书攻略

网络安全已成为当今的热门领域&#xff0c;证书在职业发展中的重要性不言而喻。但是&#xff0c;证书市场五花八门&#xff0c;选择适合自己的证书可是个大问题。别担心&#xff0c;今天我们就来聊聊CISP家族的几个热门认证&#xff0c;让你在网络安全领域的发展更加顺利&#…

ADI 配合 USRP 使用的相控阵天线 cn0566

相控阵天线 在这里插入图片描述

IDEA快捷键大全

提示&#xff1a; ① 主要记录我在使用 IDEA 开发的过程中用到的快捷键&#xff0c;可以提高开发速度。 ② 不一定要全部记住&#xff0c;主要是当一个参考文档&#xff0c;大家有一点印象&#xff0c;随时可以查看。 参考博客 > IntelliJ IDEA 快捷键说明大全&#xff08;官…
最新文章