由于答案具有单调性,考虑二分答案并验证。

如果能凑齐x堆,因为每个joke在一个牌堆里最多只能用一次,则至多只能用min(x,m)个joke.

对于每个牌,如果这个牌的总数小于x,用joke补齐剩下的,如果能补齐那么一定能组成x堆。

简单证明: 补齐完后的牌堆里每用joke一个,一定能在其他牌里面凑齐n-1个不是joke的牌。

考虑反证法,如果取某一个joke后,剩下的牌组有一个只剩下joke的话。这是不可能的,因为joke总数至多为x。

# include <cstdio>
# include <cstring>
# include <cstdlib>
# include <iostream>
# include <vector>
# include <queue>
# include <stack>
# include <map>
# include <set>
# include <cmath>
# include <algorithm>
using namespace std;
# define lowbit(x) ((x)&(-x))
# define pi 3.1415926535
# define eps 1e-
# define MOD
# define INF
# define mem(a,b) memset(a,b,sizeof(a))
# define FOR(i,a,n) for(int i=a; i<=n; ++i)
# define FO(i,a,n) for(int i=a; i<n; ++i)
# define bug puts("H");
# define lch p<<,l,mid
# define rch p<<|,mid+,r
# define mp make_pair
# define pb push_back
typedef pair<int,int> PII;
typedef vector<int> VI;
# pragma comment(linker, "/STACK:1024000000,1024000000")
typedef long long LL;
int Scan() {
int res=, flag=;
char ch;
if((ch=getchar())=='-') flag=;
else if(ch>=''&&ch<='') res=ch-'';
while((ch=getchar())>=''&&ch<='') res=res*+(ch-'');
return flag?-res:res;
}
void Out(int a) {
if(a<) {putchar('-'); a=-a;}
if(a>=) Out(a/);
putchar(a%+'');
}
const int N=;
//Code begin... int a[N], n, m; bool check(int x){
LL res=;
FOR(i,,n) {
if (a[i]>=x) continue;
res+=(x-a[i]);
}
return res<=min(m,x);
}
int main ()
{
int ma=;
scanf("%d%d",&n,&m);
FOR(i,,n) scanf("%d",a+i), ma=max(ma,a[i]);
int l=, r=ma+m+, mid;
while (l<r) {
mid=(l+r)>>;
if (l==mid) break;
if (check(mid)) l=mid;
else r=mid;
}
printf("%d\n",l);
return ;
}

最新文章

  1. jQuery 中的 39 个技巧
  2. smarty模板引擎部分内容(思维导图)
  3. test1.A[【dfs简单题】
  4. vector 之删除元素
  5. UESTC 887 方伯伯的儿童节 --树形DP
  6. easyui-datagrid 两次请求
  7. JSon_零基础_004_将Set集合对象转换为JSon格式的对象字符串,返回给界面
  8. Oracle DB 执行表空间时间点恢复
  9. JLOI 2013 卡牌游戏
  10. jquery-pager分页
  11. 写一个Redis封装类
  12. 原生js实现Ajax的原理。
  13. iOS白名单设置
  14. 嵌入式设计初体验:永远的hello,world
  15. 初学io
  16. Java匿名内部类访问外部
  17. js 创建Table,每行3列的方式
  18. java之jdbc使用
  19. Linux操作oracle——关闭、停止、重启
  20. Vue + Element UI 实现权限管理系统 (功能组件封装)

热门文章

  1. 初识Trie_对Trie的一些认识
  2. html中iframe根据子页面内容动态修改高度
  3. dsp5509的中断系统
  4. Redis系列二 Redis数据库介绍
  5. PS 放大眼睛
  6. Linux用户及权限
  7. CentOS 7.2 安装zabbix 3.4
  8. JavaWeb--------JSP语法基础学习(特别适合入门)
  9. 【system.file】使用说明
  10. 数据库Mysql的学习(六)-子查询和多表操作