LZH的多重影分身 qduoj 思维 差分
LZH的多重影分身 qduoj 思维 差分
题意
在数轴上有\(n\)个点(可以重合)和\(m\)条线段(可以重叠),你可以同时平移这\(n\)个点,询问最多可以有多少个点在线段上,输出平移的距离\(d\),和最后的答案\(val\)(如果有多个\(d\)使得\(val\)最大,则输出最小的\(d\))。
解题思路
下面的题解是我们厉害的学长给的,真是太厉害了。
首先,我们用\(ans[i]\),来代表平移\(i - MAX\)(这样表示是因为平移的距离会有负数)的距离会有多少点在线段上。
对于每一个点,我们都可以计算出该点平移到线段上的距离的范围(我们用正数代表向数轴正向移动,用负数代表向数轴负向移动),比如,有一个点位于数轴上\(4\)的位置,有两条线段\([1,2],[5,6]\),则可以让该点移动到线段上的平移距离的范围为:\([-3,-2],[1,2]\)。所以我们可以让$$ans[-3+MAX]...ans[-2+MAX],ans[1+MAX]...ans[2+MAX]$$
各增加1(这不就是区间加的操作吗?)。
这样我们遍历所有的点,就可以得到正确的\(ans\)数组了。扫描一遍\(ans\)数组记录最大值即可得到答案。
但是注意:
1.在进行区间加的操作的时候,应该采用差分的方式进行(不能暴力,使用线段树、树状数组等数据结构的时间复杂度也太高,并且相比差分代码量更大)。
2.要先把有交集的线段合并,在统计答案,否则会重复计算。
总结一下就是,求出每个点到达所有的区间所走的长度,然后在这些点上进行加一,这样我们就可以直接进行遍历所有可以走的长度,寻找最大值。学长们真是太强了。
代码实现
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int maxn=1e4+7;
const int maxm=1e3+7;
const int maxlen=1e6+7;
int pos[maxn];
struct Node
{
int l, r;
friend bool operator<(const Node a, const Node b)
{
return a.l < b.l;
}
}node[maxm];
int ans[maxlen<<1];
int n, m, cnt;
int main()
{
scanf("%d%d",&n, &m);
for(int i=0; i<n; i++)
scanf("%d", &pos[i]);
for(int i=0; i<m; i++)
scanf("%d%d",&node[i].l, &node[i].r);
sort(node, node+m);
cnt=1;
for(int i=1; i<m; i++)
{
if(node[cnt-1].r >=node[i].l )
node[cnt-1].r=max(node[cnt-1].r, node[i].r);
else
node[cnt++]=node[i];
}
int l, r;
for(int i=0; i<n; i++)
{
for(int j=0; j<cnt; j++)
{
l=node[j].l-pos[i]; r=node[j].r-pos[i];
++ans[l+maxlen];
--ans[r+maxlen+1];
}
}
int len=maxlen<<1, sum=0, delta=0, outans=0;
for(int i=0; i<len; i++)
{
sum+=ans[i];
if(sum > outans)
{
outans=sum;
delta=abs(i-maxlen);
}
else if(sum==outans && delta > abs(i-maxlen))
{
delta=abs(i-maxlen);
}
}
printf("%d %d\n", delta, outans);
return 0;
}
LZH的多重影分身 qduoj 思维 差分的更多相关文章
- Magic Stones CodeForces - 1110E (思维+差分)
E. Magic Stones time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...
- AtCoder Beginner Contest 188 D - Snuke Prime (思维,差分)
题意:你需要订阅一些服务,每个服务每天需要花费\(c_i\),要从第\(a_i\)用到第\(b_i\)天,你可以购买会员,会员每天需要花费\(C\),但是这天的服务不用再另花钱了,问你订阅这些服务的最 ...
- Straight Master Gym-101775J (思维+差分)
题意:给出N种类的数量,求是否可以把N种牌按3-5张连续的顺子打出,顺子必须连续. 分析:相当于把这个序列分成若干长度为[3,5]的区间,当然其实分成若干段大于3的区间即可.因为大于5的区间又可以分拆 ...
- T2960 全民健身【思维Dp,预处理,差分优化】
Online Judge:YCJSOI Label:Dp,思维题,预处理,滚动优化 题目描述 乐乐现在掌管一个大公司,办公楼共有n层.为了增加员工的身体素质,他决定在每层楼都建立一个活动室,活动室分乒 ...
- [The Preliminary Contest for ICPC Asia Shanghai 2019] B-Light bulbs(差分+思维)
前言 最近有很多算不上事的事,搞得有点心烦,补题难免就很水,没怎么搞,自我检讨一番~~ 说实话网络赛题目的质量还是挺高的,题目都设计的挺好的,很值得学习.这场比赛那会只有我们大二的在做,其他人去参加$ ...
- 洛谷 P4749 - [CERC2017]Kitchen Knobs(差分转换+dp,思维题)
题面传送门 一道挺有意思的思维题. 首先有一个 obvious 的结论,就是对于每个炉子,要么转到哪里都符合条件,要么存在唯一的最大值.对于转到哪儿都符合条件的炉子我们 duck 不必考虑它,故我们只 ...
- Codeforces 1108E2 Array and Segments (Hard version)(差分+思维)
题目链接:Array and Segments (Hard version) 题意:给定一个长度为n的序列,m个区间,从m个区间内选择一些区间内的数都减一,使得整个序列的最大值减最小值最大. 题解:利 ...
- 差分约束系统+(矩阵)思维(H - THE MATRIX PROBLEM HDU - 3666 )
题目链接:https://cn.vjudge.net/contest/276233#problem/H 题目大意:对于给定的矩阵 每一行除以ai 每一列除以bi 之后 数组的所有元素都还在那个L- ...
- 【思维题 集合hash 树上差分】11.5撸树
要注重问题的转化和一些结论的推断 题目描述 要致富,先撸树. 一棵树的形状可以简化为一张 $N$ 个点 $M$ 条边的图,由于装备条件限制,你只有撸两次,也就是删去两条边,当这张图不联通时,就意味着树 ...
随机推荐
- 9030PCI CAN驱动开发点滴
1.配置EEPROM. 使用PlxMon打开9030,基本修改Spacex(0,1,2,3), Chip selectx(0,1,2,3), 中断状态INTCSR(0x74), 其他(0x78),详细 ...
- Codeforces 785 E. Anton and Permutation(分块,树状数组)
Codeforces 785 E. Anton and Permutation 题目大意:给出n,q.n代表有一个元素从1到n的数组(对应索引1~n),q表示有q个查询.每次查询给出两个数l,r,要求 ...
- Linux之防火墙iptables
一.检查iptables服务状态 1.首先检查iptables服务的状态 [root@bogon ~]# service iptables status iptables: Firewall is n ...
- Linux网络编程三、 IO操作
当从一个文件描述符进行读写操作时,accept.read.write这些函数会阻塞I/O.在这种会阻塞I/O的操作好处是不会占用cpu宝贵的时间片,但是如果需要对多个描述符操作时,阻塞会使同一时刻只能 ...
- docker之CPU配额参数的混合使用
在启动容器的时候有很多参数,这里来实践一下与CPU相关的参数. 实例: 创建两个容器,docker10.docker20,让两个容器只运行在CPU0上,然后测试CPU使用率. [root@openst ...
- Partial Dependence Plot
Partial Dependence就是用来解释某个特征和目标值y的关系的,一般是通过画出Partial Dependence Plot(PDP)来体现. PDP是依赖于模型本身的,所以我们需要先训练 ...
- (十四)C语言之一维数组、二维数组
- Anaconda 改为国内镜像的方法
Anaconda的conda 特别好用 但如果用国外的镜像,慢的出奇 可以改为了国内镜像会好很多 conda config --add channels https://mirrors.tuna.ts ...
- 移动App双周版本迭代策略
对于移动互联网产品来说,迭代的速度就是生命.我创业时做移动App时是一周一版,而现在是2周1版.相比起小公司,大公司迭代时间虽长,却更为不易,因为大公司流程更多,参与人数更多,需求更多,实现这样的快速 ...
- yum源安装mysql数据库 添加密码
学习mysql数据库时,安装的问题一直很烦恼,linux的不同版本的安装方式都可能不同,这里是我学习时的一些总结.也是刚刚开始学习,大佬勿喷,谢谢啦!!! 1.查看是否已经安装 2.如果没安装 yum ...