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 ...
随机推荐
- harbor重启后无法自启动解决方案
1. 创建 systemd 服务单元文件 编辑服务文件: 使用以下命令创建并编辑 systemd 服务文件: sudo vim /etc/systemd/system/harbor.service 添 ...
- Ubuntu 安装 Docker Desktop
介绍 Docker 有两种版本:Docker Desktop 和 Docker Engine (也称作 Docker CE).Docker Desktop 是带图形界面的版本,非常适合需要在桌面环境中 ...
- 【Appium】之自动化定位总结
一.同级定位时,先定位上级 我想定位[必填]框,我先定位[姓名]的同一个上级 self.driver.find_element(MobileBy.XPATH,"//*[contains(@t ...
- 【YashanDB数据库】大事务回滚导致其他操作无法执行,报错YAS-02016 no free undo blocks
问题现象 客户将一个100G的表的数据插入到另一个表中,使用insert into select插入数据.从第一天下午2点开始执行,到第二天上午10点,一直未执行完毕. 由于需要实施下一步操作,客户k ...
- Linux 终端运行命令时出现多行带有加号的信息(详见文章内容)
++_vte_ prompt_ command +++ HISTTIMEFORMAT= +++ history 1 +++ sed 's/^ *[0-9] \+ *//' ++ local ' com ...
- Figma 学习笔记 – Image
参考: Figma Tutorial: Images 3 Ways to Insert Image 1. rectangle / frame + fill 画一个 rectangle / frame ...
- ASP.NET Core 单元测试
前言 单元测试是好, 但是也很花时间. 有些功能封装好了以后也不怎么会再打开, 所以通常就是徒手测试一下, 过了就过了. 但是往往就是那么神奇, 就是会有需求漏掉. 后来要加, 又由于不想潜水, 对自 ...
- thinkphp中的or,like,in等联合查询
数据库中的两个字段有一个字段等于查询条件时,下面两个方法都是可以的: (1) $where['a.goods_name|a.goods_sn'] = array('like',"%$keyW ...
- Java日期时间API系列22-----Jdk8中java.time包中的新的日期时间API类,Month月份和DayOfWeek星期的计算。
Java8中为月份和星期新增的了,Month和DayOfWeek,来处理月份和星期的特殊问题,这2个类都是枚举类,对Month.DayOfWeek源码说明和简单应用,月份英文,月份英文简称,月份中文, ...
- IOC注入分类 依赖注入
依赖注入 也就是服务的注入 可以理解 一些服务的容器,目的:把一些全局需要使用的资源,服务放到某个接口中,使其可以在全局中使用 和前端的状态管理工具实现的功能差不多 注册服务的三种形式 单例模式Ad ...