
Codeforces Round #611 (Div. 3) E. New Year Parties (贪心)
题意:给定一个初始序列,规定可以对序列的每个元素进行+1、-1或者不变的操作,一顿操作过后,序列不同元素的个数为X,求x的最大和最小值 思路:求最小值容易想,可以先排序再去重,只要有一段元素比如1,2,3是连续且相差为1的肯定可以合并在一起,但是这里有个漏洞,就是比如2 4其实也是可以合并在一起的,把这个条件加上就行。 至于求最大值的话,可以先统计每个数的个数,然后枚举每个数,只要左边有空位就往左边移,如果自己还有多的就往右边移。
发布日期:2021-05-08 15:15:04
浏览次数:15
分类:精选文章
本文共 934 字,大约阅读时间需要 3 分钟。


#includeusing namespace std;const int maxn=2e5+10;typedef long long ll;int n,a[maxn],b[maxn],maxx=0,num[maxn]={ 0},ans;int main(){ scanf("%d",&n); for(int i=1;i<=n;++i) scanf("%d",&a[i]),b[i]=a[i],maxx=max(maxx,a[i]),num[b[i]]++; sort(a+1,a+1+n); sort(b+1,b+1+n); int size=unique(a+1,a+1+n)-a-1; int j=1; a[size+1]=1e6,a[size+2]=1e9; while(j<=size) { if(a[j+2]-a[j+1]==1&&a[j+1]-a[j]==1) j+=3; else if(a[j+1]-a[j]==1) j+=2; else if(a[j+1]-a[j]==2) j+=2; else j++; ans++; } printf("%d ",ans); ans=0; for(int i=1;i<=n+1;++i) { if(num[i]==0) continue; if(num[i-1]==0) num[i]--,num[i-1]++; if(num[i]>1) num[i]--,num[i+1]++; } for(int i=0;i<=maxx+1;++i) if(num[i]) ans++; printf("%d\n",ans);}
发表评论
最新留言
能坚持,总会有不一样的收获!
[***.219.124.196]2025年04月12日 12时47分22秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
ACM/NCPC2016 C Card Hand Sorting(upc 3028)
2019-03-05
ubuntu学习笔记-常用文件、命令以及作用(hosts、vim、ssh)
2019-03-05
SLAM学习笔记-求解视觉SLAM问题
2019-03-05
普歌-允异团队-HashMap面试题
2019-03-05
还在一个一个手动安装虚拟机吗?Cobbler自动部署装机一键最小化安装打把游戏就好了
2019-03-05
程序员应该知道的97件事
2019-03-05
create-react-app路由的实现原理
2019-03-05
Linux环境变量配置错误导致命令不能使用(杂谈)
2019-03-05
openstack安装(九)网络服务的安装--控制节点
2019-03-05
shell编程(六)语言编码规范之(变量)
2019-03-05
vimscript学习笔记(二)预备知识
2019-03-05
Android数据库
2019-03-05
HTML基础,块级元素/行内元素/行内块元素辨析【2分钟掌握】
2019-03-05
STM8 GPIO模式
2019-03-05
omnet++
2019-03-05
23种设计模式一:单例模式
2019-03-05
Qt中的析构函数
2019-03-05
C语言实现dijkstra(adjacence matrix)
2019-03-05
三层框架+sql server数据库 实战教学-徐新帅-专题视频课程
2019-03-05