博客
关于我
Codeforces Round #611 (Div. 3) E. New Year Parties (贪心)
阅读量:389 次
发布时间:2019-03-05

本文共 934 字,大约阅读时间需要 3 分钟。

在这里插入图片描述
在这里插入图片描述
题意:给定一个初始序列,规定可以对序列的每个元素进行+1、-1或者不变的操作,一顿操作过后,序列不同元素的个数为X,求x的最大和最小值
思路:求最小值容易想,可以先排序再去重,只要有一段元素比如1,2,3是连续且相差为1的肯定可以合并在一起,但是这里有个漏洞,就是比如2 4其实也是可以合并在一起的,把这个条件加上就行。
至于求最大值的话,可以先统计每个数的个数,然后枚举每个数,只要左边有空位就往左边移,如果自己还有多的就往右边移。

#include
using 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);}

转载地址:http://yoewz.baihongyu.com/

你可能感兴趣的文章
nginx报错:the “ssl“ parameter requires ngx_http_ssl_module in usrlocalnginxconfnginx.conf128
查看>>
nginx日志分割并定期删除
查看>>
Nginx日志分析系统---ElasticStack(ELK)工作笔记001
查看>>
Nginx映射本地json文件,配置解决浏览器跨域问题,提供前端get请求模拟数据
查看>>
nginx最最最详细教程来了
查看>>
Nginx服务器---正向代理
查看>>
Nginx服务器上安装SSL证书
查看>>
Nginx服务器基本配置
查看>>
Nginx服务器的安装
查看>>
Nginx标准配置文件(包括反向代理、大文件上传、Https证书配置、文件预览等)
查看>>
Nginx模块 ngx_http_limit_conn_module 限制连接数
查看>>
Nginx模块 ngx_http_limit_req_module 限制请求速率
查看>>
nginx添加模块与https支持
查看>>
nginx状态监控
查看>>
Nginx用户认证
查看>>
Nginx的location匹配规则的关键问题详解
查看>>
Nginx的Rewrite正则表达式,匹配非某单词
查看>>
Nginx的使用总结(一)
查看>>
Nginx的使用总结(三)
查看>>
Nginx的使用总结(二)
查看>>