Codeforces Round 975 Div.2 C题 解析
C题
题目链接:Problem - C - Codeforces
题目描述

思路
- 对于这道题,首先我们能想到最小的组数肯定是数量最多的那个卡片的数量(mx),因为这个值的每一个卡片不能在同一个组里面。
- 我们首先需要考虑是否能够保住这个sum/mx这个答案,甚至可以用k来增加答案的值。
- 而要保住这个答案,要不就是刚好sum%mx==0,即刚好没加k前大小就是sum/mx,然后因为有mx组,所以卡组大小又多了k/mx,
- 另一种可能就是k和多出的牌数再凑一层(指的是让sum%mx==0,用k来增大sum)出来,判断需要补的牌数和k的大小差即可。
- 如果两者都不可以,那就需要减少卡组大小,看剩余的牌数可否成为新的组。
- 如果减少一次卡组大小也不可以,就需要把卡组大小再减小,减小了卡组大小,剩余的数量就多了mx,再判断是否可以成为新的组,一直循环直到可以即输出。
时间复杂度:O(n)
代码
#include <bits/stdc++.h>
#define int long long
using namespace std;
const int N=2e5+10;
int n,k;
int a[N];
void solve()
{
cin>>n>>k;
int mx=0,sum=0;
for(int i=0;i<n;i++)
{
cin>>a[i];
sum+=a[i];
mx=max(mx,a[i]);
}
int mans=sum/mx;
//如果刚好就直接k来增添答案即可
if (sum % mx == 0) {
cout << min(mans + k / mx,n) << endl;
return;
}
//如果不够就看k能不能和多出来的再组一行
if (k >= (mx - sum % mx)) {
k -= (mx - sum % mx);
mans++;
cout << min(mans + k / mx,n) << endl;
return;
}
//此时k的作用不是继续增加mans,而是尽可能保住mans
//k补不上空缺,我们先尝试增加mx,再不行就减层
int res = sum % mx;//res标记的是指多出来的数
while (1) {
if (res % mans == 0) {//如果能够刚好保住
cout << mans << endl;
return;
}
if (k >= (mans - res % mans)) {//如果能用k来保住
cout << mans << endl;
return;
}
mans--;
res += mx;//少了一层多出来的就多mx
}
}
signed main()
{
int t;
cin>>t;
while(t--)
{
solve();
}
return 0;
}
警示:
- 由于数据范围较大,所以我们需要用到long long,不然会爆数据
- 因为只有n个数,所以肯定答案肯定小于等于n,所以在第一种情况要和n取最小值。
Codeforces Round 975 Div.2 C题 解析的更多相关文章
- Codeforces Round #378 (Div. 2) D题(data structure)解题报告
题目地址 先简单的总结一下这次CF,前两道题非常的水,可是第一题又是因为自己想的不够周到而被Hack了一次(或许也应该感谢这个hack我的人,使我没有最后在赛后测试中WA).做到C题时看到题目情况非常 ...
- Codeforces Round #612 (Div. 2) 前四题题解
这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...
- Codeforces Round #713 (Div. 3)AB题
Codeforces Round #713 (Div. 3) Editorial 记录一下自己写的前二题本人比较菜 A. Spy Detected! You are given an array a ...
- Codeforces Round #833 (Div. 2)补题
Codeforces Round #833 (Div. 2) D. ConstructOR 知识点:高位和对低位无影响 一开始以为和广州的M一样,是数位dp,后来发现只要找到一个就行 果然无论什么时候 ...
- Codeforces Round #552 (Div. 3) A题
题目网址:http://codeforces.com/contest/1154/problem/ 题目意思:就是给你四个数,这四个数是a+b,a+c,b+c,a+b+c,次序未知要反求出a,b,c,d ...
- Codeforces Round #412 Div. 2 补题 D. Dynamic Problem Scoring
D. Dynamic Problem Scoring time limit per test 2 seconds memory limit per test 256 megabytes input s ...
- Codeforces Round #271 (Div. 2) E题 Pillars(线段树维护DP)
题目地址:http://codeforces.com/contest/474/problem/E 第一次遇到这样的用线段树来维护DP的题目.ASC中也遇到过,当时也非常自然的想到了线段树维护DP,可是 ...
- Codeforces Round #425 (Div. 2))——A题&&B题&&D题
A. Sasha and Sticks 题目链接:http://codeforces.com/contest/832/problem/A 题目意思:n个棍,双方每次取k个,取得多次数的人获胜,Sash ...
- Codeforces Round #579 (Div. 3) 套题 题解
A. Circle of Students 题目:https://codeforces.com/contest/1203/problem/A 题意:一堆人坐成一个环,问能否按逆时针或者顺时针 ...
- Codeforces Round #786 (Div. 3) 补题记录
小结: A,B,F 切,C 没写 1ll 对照样例才发现,E,G 对照样例过,D 对照样例+看了其他人代码(主要急于看后面的题,能调出来的但偷懒了. CF1674A Number Transforma ...
随机推荐
- 理解async 和 await
await 后面接的是promise,await语句下面(注意:不是await后面,而是await所在语句的下面,即下行以后)的代码就相当在promise.then()里面执行,有文章说 await后 ...
- Java并发之volatile关键字内存可见性问题
Java并发之volatile关键字内存可见性问题 线程之间数据共享案例 我们先来看一个场景: Main函数启动后,调用一个线程向list中添加数据.List的size为5的时候,设置变量flag为t ...
- LCD屏幕显示PNG图像
正点原子LCD屏幕显示PNG图像 本文概要 这段时间在学习正点原子的IMX6ULL开发板,在应用编程中有一个代码练习是需要在LCD屏幕上显示PNG图像,但由于我的屏幕参数和教程中的有些出入,于是经过自 ...
- Angular Material 18+ 高级教程 – CDK Layout の Breakpoints
前言 CDK Layout 主要是用于处理 Breakpoints,它底层是依靠 window.matchMedia 来实现的. Material Design 2 & 3 Breakpoin ...
- TypeScript – Get Started
前言 我学 TypeScript 的时候是 Angular 2.0 beta 的年代... 现在 Angular 都快 14 了. 但由于已经有 1 年半没有写 Angular 和 TypeScrip ...
- CSS & JS Effect – Hamburger Menu
效果 参考: Youtube – Responsive Navigation Menu Bar + Hamburger Menu Toggle - Only with CSS Youtube – Ma ...
- 微信小程序开发疑难
1.开发者工具在小程序webview中注入wx时会提示token过期,但真机正常
- 一个 tomcat 下如何部署多个项目?附详细步骤
一个tomcat下如何部署多个项目?Linux跟windows系统下的步骤都差不多,以下linux系统下部署为例.windows系统下部署同理. 一.不修改端口,部署多个项目 清楚tomcat目录结构 ...
- Adobe Pr 软件报错,此效果需要GPU加速
事件起因: 某同事使用PR软件报错,报错截图如下: 解决办法: 1.在pr菜单栏选择文件-项目设置-常规-视频渲染和回放-渲染程序,切换到Mercury Playback Engine GPU加速 ...
- HBase集群安装及集成
Hbase集群搭建 注意:在安装hbase或者hadoop的时候,要注意hadoop和hbase的对应关系.如果版本不对应可能造成系统的不稳定和一些其他的问题.在hbase的lib目录下可以看到had ...