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; }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1099074.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UniApp 全面介绍与快速上手

在多端应用开发需求激增的当下&#xff0c;开发者往往需要为微信小程序、App、H5、支付宝小程序等多个平台分别开发代码&#xff0c;效率低且维护成本高。UniApp 作为一款基于 Vue.js 的跨端开发框架&#xff0c;以 “一套代码&#xff0c;多端运行” 为核心优势&#xff0c;成…

GitHub Wiki使用指南:为Miniconda-Python3.11项目搭建文档中心

GitHub Wiki 与 Miniconda-Python3.11&#xff1a;构建高效协作的文档与环境体系 在科研团队和中小型开发项目中&#xff0c;一个常见的痛点是&#xff1a;代码能跑通&#xff0c;但换个人就“环境报错”&#xff1b;实验结果无法复现&#xff0c;不是因为模型有问题&#xff0…

基于STM32的模拟信号采集系统深度剖析

从零构建高精度模拟信号采集系统&#xff1a;STM32实战全解析 你有没有遇到过这样的问题&#xff1f; 调试一个温度采集模块&#xff0c;明明传感器输出很稳定&#xff0c;可ADC读回来的数据却像“心电图”一样跳个不停&#xff1b; 想做电池电压监测&#xff0c;采样频率设为…

JLink驱动安装后仍提示未连接?深度剖析权限问题

JLink插上却“未连接”&#xff1f;别重装驱动了&#xff0c;90%的问题出在这里 你有没有遇到过这样的情况&#xff1a; J-Link明明插在电脑上&#xff0c;指示灯也亮着&#xff1b; SEGGER的软件包已经装好&#xff0c; JLinkExe 命令也能运行&#xff1b; 可一执行 co…

CF GYM106049 G [构造][数论]

Problem - G - Codeforces 题目大意为将1~n 分为几个连续的区间 然后每个区间的乘积记作pi 求gcd(pi......)的最小值 对于一个长度为v的数组 他的乘积为num1(num11)(num12)....(num1v-1) 这个乘积一定是v!的倍数 我们可以利用组合数证明 设组合数c(num1v-1,v) 即…

Pyenv shell会话管理:临时切换Miniconda-Python3.11之外的版本

Pyenv shell会话管理&#xff1a;临时切换Miniconda-Python3.11之外的版本 在AI开发日益标准化的今天&#xff0c;许多云平台和实验室都默认提供“Miniconda-Python3.11”作为基础镜像——开箱即用、稳定兼容。但现实项目中&#xff0c;我们常遇到这样的困境&#xff1a;某个旧…

Pyenv install python3.11慢?直接使用预编译Miniconda镜像更快

Pyenv install python3.11慢&#xff1f;直接使用预编译Miniconda镜像更快 在人工智能和数据科学项目中&#xff0c;开发者最怕的不是写不出模型&#xff0c;而是卡在环境配置上——尤其是当你输入 pyenv install 3.11 后&#xff0c;看着终端里一行行编译日志缓慢滚动&#xf…

基于Miniconda-Python3.11镜像的AI开发环境搭建全攻略

基于Miniconda-Python3.11镜像的AI开发环境搭建全攻略 在人工智能项目日益复杂的今天&#xff0c;你是否曾因“这个代码在我机器上明明能跑”而陷入团队协作的尴尬&#xff1f;又或者在复现一篇论文时&#xff0c;被层层嵌套的依赖版本问题拖入无尽调试的深渊&#xff1f;这些看…

HTML可视化调试技巧:利用Miniconda-Python3.11集成TensorBoard进行训练监控

HTML可视化调试技巧&#xff1a;利用Miniconda-Python3.11集成TensorBoard进行训练监控 在深度学习项目的开发过程中&#xff0c;最让人头疼的往往不是模型结构设计&#xff0c;而是训练过程中的“黑箱”感——损失曲线忽高忽低&#xff0c;准确率迟迟不涨&#xff0c;却不知道…

Miniconda环境迁移方案:将本地开发环境无缝部署到GPU云机

Miniconda环境迁移方案&#xff1a;将本地开发环境无缝部署到GPU云机 在AI模型训练日益依赖高性能GPU的今天&#xff0c;一个常见的困境是&#xff1a;本地调试好好的代码&#xff0c;一上云端就报错——不是包版本冲突&#xff0c;就是CUDA不兼容。这种“在我机器上明明能跑”…

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

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

施密特触发器在工业报警电路中的实际应用:项目应用

施密特触发器如何“稳准狠”地守护工业报警系统&#xff1f;一个真实项目中的硬核实战解析在某次为冶金厂改造高温炉监控系统的现场调试中&#xff0c;我们遇到了这样一个问题&#xff1a;温度刚达到设定值&#xff0c;蜂鸣器就开始“抽风式”报警——响两秒停一秒&#xff0c;…

Jupyter密码设置教程:保护Miniconda-Python3.11中的敏感数据

Jupyter密码设置教程&#xff1a;保护Miniconda-Python3.11中的敏感数据 在科研与AI开发日益依赖远程计算资源的今天&#xff0c;一个看似简单的操作失误——比如忘记给Jupyter Notebook设密码——就可能让整个服务器暴露在公网攻击之下。我们常看到这样的新闻&#xff1a;某高…

Java Timer类:如何创建定时任务?

文章目录Java Timer类&#xff1a;如何创建定时任务&#xff1f;一、Timer类&#xff1a;定时任务的“老伙计”1. Timer的基本使用示例代码&#xff1a;输出结果&#xff1a;2. TimerTask&#xff1a;任务的具体实现二、创建单次定时任务示例代码&#xff1a;输出结果&#xff…

基于Keil的STM32 HardFault调试操作指南

STM32 HardFault调试实战&#xff1a;从崩溃现场到精准修复你有没有遇到过这样的场景&#xff1f;程序运行得好好的&#xff0c;突然“啪”一下卡死&#xff0c;或者不断重启。串口毫无输出&#xff0c;LED定格在某个状态——典型的HardFault征兆。在STM32开发中&#xff0c;Ha…

清华源无法连接?备用USTC源配置Miniconda-Python3.11的方法

清华源无法连接&#xff1f;备用USTC源配置Miniconda-Python3.11的方法 在人工智能与数据科学项目中&#xff0c;搭建一个稳定、高效的Python开发环境是第一步&#xff0c;也是最关键的一步。然而&#xff0c;许多开发者都曾经历过这样的场景&#xff1a;满怀期待地运行 conda…

Conda-pack打包迁移:将Miniconda-Python3.11环境复制到无网络机器

Conda-pack 打包迁移&#xff1a;将 Miniconda-Python3.11 环境复制到无网络机器 在人工智能和数据科学项目中&#xff0c;一个常见的工程难题是&#xff1a;如何把本地调试好的 Python 环境完整迁移到无法联网的服务器或边缘设备上&#xff1f; 你有没有遇到过这种情况——在…

Jupyter输出被截断?调整Miniconda-Python3.11的显示限制

Jupyter输出被截断&#xff1f;调整Miniconda-Python3.11的显示限制 在数据科学和AI开发中&#xff0c;你是否曾遇到这样的场景&#xff1a;刚加载完一个大型CSV文件&#xff0c;满怀期待地执行 df.head(50)&#xff0c;结果输出却是一行冰冷的 [50 rows x 30 columns]&#xf…

CMD操作的学习

一.什么是CMDCMD英文全称为Command Prompt&#xff08;命令提示符&#xff09;&#xff0c;是Windows操作系统中的一个命令行解释器程序。它允许用户通过输入文本命令来执行各种操作&#xff0c;例如管理文件、运行程序、配置系统设置等。1.基本信息全称&#xff1a;Command Pr…

GitHub Gist代码片段分享:快速传播Miniconda-Python3.11配置经验

Miniconda-Python3.11 环境标准化实践&#xff1a;从配置到协作的闭环 在数据科学与 AI 工程项目中&#xff0c;你是否经历过这样的场景&#xff1f;新同事入职第一天&#xff0c;花了整整两天才把环境配好&#xff1b;本地训练好的模型换一台机器就跑不起来&#xff1b;论文复…