news 2026/6/9 22:05:53

codefoeces EDU186 D[组合数学] E[贪心]

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
codefoeces EDU186 D[组合数学] E[贪心]

设所有盒子的总和为 sum 人数为n 则一定会经过sum/n轮 并且前sum%n个人会再进行一次

这道题如果最后构成了一个合法的方案 那么一定有:

1.最多的人的盒子内的个数不超过sum/n+1

那么就变成了一道组合数学的问题 我们先找出所有的人的和 然后计算出上限 判断有无人多余上限 多的话就不合法 如果不存在超过上限的情况 那么将所有刚好等于sum/n+1的人排在前面 他们的整体位置不能改变但是相对位置可以改变 记录刚哈后等于sum/n+1的人数为c 他们是不能碰0盒子的

有sum/n+1次的数字有sum%n个 那么还剩下sum%n-c个名额 那么我们先算出前c个数字的全排列 然后再算后面的数字的全排列即可

第一次全排列 b个位置中出c个人即可 剩下的全排列把剩余位置全部占领即可

#include <bits/stdc++.h> using namespace std; const int N=55,mod=998244353; long long a[N]; void solve(){ int n;cin>>n; long long sum=0; for(int i=0;i<=n;i++){ cin>>a[i]; sum+=a[i]; } int A=sum/n +1; int c=0,d=n,b=sum%n; long long ans=1; for(int i=1;i<=n;i++){ if(a[i]>A){ans=0;cout<<0<<'\n';return;} if(a[i]==A)++c,--d; } while(c--)ans=ans*b%mod,b--; b+=n-(sum%n); while(d--)ans=ans*b%mod,b--; cout<<ans<<'\n'; } int main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); int t;cin>>t; while(t--)solve(); return 0; }

E

贪心 每个人都有基础花销和额外花销 首先将所有人的基础花销减去 然后每个人有一个额外花销 那么我们先用礼盒 尽可能的去掉高额外花销的人 然后再花剩下的钱 优先满足额外花销最小的人 这样得到的结果最大

代码变量解释: a[]存储礼盒 升序排序 b[]存储每个礼盒能够解决的花销 st存储不能用礼盒解决人的额外花销

我们每一个人分配给刚好能用礼盒解决的最小礼盒 如果没有那么就分配给结尾 也就是m+1 这样每个人只会被分配一次 然后我们从小到大遍历每个气球 然后将这个气球能解决的所有的花销都放入集合中 这样以来 由于升序 任何一个当前放出的气球 都可以解决当前集合中的所有人的 花销 那么我们选择一个最大的即可 这样的收益最大 处理完每个气球后 我们再考虑花钱即可

#include <bits/stdc++.h> using namespace std; const int N=2e5+5; typedef long long ll; long long a[N]; vector<ll>b[N]; void solve(){ long long n,m,k;cin>>n>>m>>k; for(int i=1;i<=m;i++){ cin>>a[i]; }sort(a+1,a+1+m); for(int i=1;i<=m+1;i++)b[i].clear(); multiset<ll>st; long long ans=0; for(int i=1;i<=n;i++){ long long x,y,z;cin>>x>>y>>z; k-=y; //减去基本花销 int p=lower_bound(a+1,a+1+m,x)-a; //寻找可以满足的第一个礼盒 如果没有就返回结尾+1 b[p].push_back(z-y);//将每个花销分配给第一个能满足他的礼盒 }//遍历所有的礼盒以及结尾+1 因为有些无法通过满足的人被分配给了m+1 for(int i=1;i<=m+1;i++){ for(int j:b[i])st.insert(j); //将分配给当前礼盒的放出来 当前的气球一定可以解决所有的已经放出来的人 那么我们选择一个最大的即可 这样最大化利益 if(i<=m&&!st.empty()){ auto o=prev(st.end());//取一个花销最大的出来 然后消除掉 ++ans; st.erase(o); } } for(int i:st){ //花钱满足额外消费尽量少的 if(k>=i)k-=i,ans++; } cout<<ans<<'\n'; } int main() { ios::sync_with_stdio(0); cin.tie(0); cout.tie(0); int t;cin>>t; while(t--)solve(); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 3:27:38

Anaconda Prompt替代品:在Miniconda-Python3.11中自定义shell命令

Anaconda Prompt替代品&#xff1a;在Miniconda-Python3.11中自定义shell命令 你有没有遇到过这样的场景&#xff1f;刚接手一个AI项目&#xff0c;同事说“代码在我机器上跑得好好的”&#xff0c;结果你一运行就报错&#xff1a;ModuleNotFoundError、CUDA version mismatch、…

作者头像 李华
网站建设 2026/5/30 22:54:35

Jupyter Lab安装教程:比Notebook更强大的Miniconda-Python3.11 IDE

Jupyter Lab Miniconda-Python3.11&#xff1a;构建现代AI开发环境的终极实践 在数据科学和人工智能项目日益复杂的今天&#xff0c;一个稳定、高效且可复现的开发环境&#xff0c;早已不再是“锦上添花”&#xff0c;而是决定研发效率与成果可靠性的关键基础设施。你是否曾因…

作者头像 李华
网站建设 2026/6/9 21:07:32

Anaconda配置PyTorch环境繁琐?换用Miniconda更轻便高效

Anaconda配置PyTorch环境繁琐&#xff1f;换用Miniconda更轻便高效 在人工智能项目开发中&#xff0c;你是否曾遇到这样的场景&#xff1a;刚配好的 PyTorch 环境运行得好好的&#xff0c;结果同事拿你的代码却跑不起来&#xff1f;或者一台服务器上多个实验互相“打架”&#…

作者头像 李华
网站建设 2026/6/9 22:04:22

Miniconda vs Anaconda:为何PyTorch开发者更偏爱Miniconda-Python3.11

Miniconda vs Anaconda&#xff1a;为何 PyTorch 开发者更偏爱 Miniconda-Python3.11 在深度学习项目日益复杂的今天&#xff0c;一个干净、可控且可复现的开发环境&#xff0c;往往比模型结构本身更能决定实验成败。你是否曾遇到过这样的场景&#xff1a;同事运行正常的训练脚…

作者头像 李华
网站建设 2026/6/9 21:07:32

Python安装opencv-contrib-python:在Miniconda-Python3.11中扩展CV功能

Python安装opencv-contrib-python&#xff1a;在Miniconda-Python3.11中扩展CV功能 你有没有遇到过这样的情况&#xff1a;写好了一段图像特征匹配的代码&#xff0c;信心满满地运行&#xff0c;结果报错 module cv2 has no attribute SIFT_create&#xff1f; 别急&#xff0c…

作者头像 李华
网站建设 2026/6/9 21:05:07

清华源加速PyTorch安装:Miniconda-Python3.11环境下实测方案

清华源加速PyTorch安装&#xff1a;Miniconda-Python3.11环境下实测方案 在实验室的深夜&#xff0c;你正准备复现一篇顶会论文——模型结构清晰、数据集已准备好&#xff0c;却卡在了最不该出问题的地方&#xff1a;conda install pytorch 卡在 20%&#xff0c;下载速度不到 5…

作者头像 李华