题目

你有\(n\)个士兵,需要将他们分成\(m\)组,每组可以为0;

现在这些士兵要去攻打\(m\)个敌人,每个敌人的生命值为\(hp_i\) ;

一轮游戏中一组士兵选定一个攻打的敌人,敌人生命值-=这组的人数;

胜利的判定是所有敌人的生命值为非正的;

输出胜利的最小轮数,可以达到最小轮数的分配方式,并输出每轮的策略;

\(1 \le m \le n \le 10^6 \ , \ 1 \le \sum hp_i \le 10^6\) ;

题解

  • 答案的下界是\(\lceil \frac{\sum_{i=1}^{m} \ hp_i} n \rceil\) ,考虑构造这个下界;

  • 注意到所有的和为\(n\),首先让 ​$ hp_i $ 对 ​$ n $ 取模;

    只需要构造

    \[\begin{cases}
    s_i &= (\sum_{j=1}^{i} hp_j) \ mod \ n &i \lt m \\
    s_i &= n &i = m \\
    \end{cases}
    \]

  • 排序得到\(s_1,\cdots,s_{m-1},s_m\),构造\(s_i-s_{i-1}\)即可;

  • 容易知道只有最后一次的\(n\)没有被充分利用,所以满足下界;

  • 再 \(for\) 一遍模拟取模的过程求出策略即可;

    #include<bits/stdc++.h>
    #define mk make_pair
    #define fi first
    #define se second
    #define pb push_back
    using namespace std;
    const int N=1000010;
    int n,m,a[N],pos[N],cnt;
    pair<int,int>b[N];
    vector<int>ans[N];
    char gc(){
    static char*p1,*p2,s[1000000];
    if(p1==p2)p2=(p1=s)+fread(s,1,1000000,stdin);
    return(p1==p2)?EOF:*p1++;
    }
    int rd(){
    int x=0;char c=gc();
    while(c<'0'||c>'9')c=gc();
    while(c>='0'&&c<='9')x=(x<<1)+(x<<3)+c-'0',c=gc();
    return x;
    }
    char ps[1000000],*pp=ps;
    void flush(){
    fwrite(ps,1,pp-ps,stdout);
    pp=ps;
    }
    void push(char x){
    if(pp==ps+1000000)flush();
    *pp++=x;
    }
    void write(int x){
    static int sta[20],top;
    if(!x){push('0');return;}
    while(x)sta[++top]=x%10,x/=10;
    while(top)push(sta[top--]^'0');
    }
    int main(){
    // freopen("G.in","r",stdin);
    // freopen("G.out","w",stdout);
    n=rd();m=rd();
    for(int i=1;i<=m;++i){
    a[i]=rd();
    int tmp=a[i]/n;
    for(int k=1;k<=tmp;++k)
    for(int j=1;j<=m;++j)ans[j].pb(i);
    a[i]%=n;
    }
    for(int i=1,now=0;i<=m;++i){
    now+=a[i];
    if(now>=n)now-=n;
    if(i!=m)b[i]=mk(now,i);
    }
    sort(b+1,b+m);
    b[m]=mk(n,m);
    b[0]=mk(0,0);
    for(int i=1;i<=m;++i)pos[b[i].se]=i;
    for(int i=1,lst=1,now=0;i<=m;++i){
    now+=a[i];
    if(now>=n){
    for(;lst<=m;++lst)ans[lst].pb(i);
    lst=0;now-=n;
    }
    if(!now)continue;
    for(;lst<=pos[i];++lst)ans[lst].pb(i);
    }
    cnt=ans[1].size();
    write(cnt),push('\n');
    for(int i=1;i<=m;++i)write(b[i].fi-b[i-1].fi),push(' ');
    push('\n');
    for(int i=0;i<cnt;++i){
    for(int j=1;j<=m;++j)write(ans[j][i]),push(' ');
    push('\n');
    }
    flush();
    return 0;
    }

【cf contest 1119 G】Get Ready for the Battle的更多相关文章

  1. 【cf contest 1119 H】Triple

    题目 给出 \(n\) 个三元组\(\{ a_i,b_i,c_i \}\)和\(x,y,z\): 将每个三元组扩展成(\(x\)个\(a_i\),\(y\)个\(b_i\),\(z\)个\(c_i\) ...

  2. 【codeforces contest 1119 F】Niyaz and Small Degrees

    题目 描述 \(n\) 个点的树,每条边有一个边权: 对于一个 \(X\) ,求删去一些边后使得每个点的度数 \(d_i\) 均不超过 \(X\) 的最小代价: 你需要依次输出 \(X=0 \to n ...

  3. 【Cf Edu #47 G】Allowed Letters

    这个题大概就是每一个位置都有一个能填字符的限制(一个点集),给出已有的$n$个字符,问能填出的最小字典序的字符串. 总体思路是贪心,每一位尽量选最小的字符. 关键在于判断在某位选了一个字符后,接下来的 ...

  4. B. Lost Number【CF交互题 暴力】

    B. Lost Number[CF交互题 暴力] This is an interactive problem. Remember to flush your output while communi ...

  5. 【CF contest/792/problem/E】

    E. Colored Balls time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  6. 【CF edu 27 G. Shortest Path Problem?】

    time limit per test 3 seconds memory limit per test 512 megabytes input standard input output standa ...

  7. 3.26-3.31【cf补题+其他】

      计蒜客)翻硬币 //暴力匹配 #include<cstdio> #include<cstring> #define CLR(a, b) memset((a), (b), s ...

  8. 【cf补题记录】Codeforces Round #608 (Div. 2)

    比赛传送门 再次改下写博客的格式,以锻炼自己码字能力 A. Suits 题意:有四种材料,第一套西装需要 \(a\).\(d\) 各一件,卖 \(e\) 块:第二套西装需要 \(b\).\(c\).\ ...

  9. 【郑轻邀请赛 G】密室逃脱

    [题目链接]:https://acm.zzuli.edu.cn/zzuliacm/problem.php?id=2133 [题意] [题解] 考虑每一个二进制数的最高位->第i位; 肯定是1(这 ...

随机推荐

  1. 深入理解JVM(三) -- 对象的内存布局和访问定位

    一 对象的内存布局: 在HotSpot虚拟机中,对象在内存中存储的布局可以分为3块区域:对象头(Header),实例数据(Instance Data)和对齐填充(Padding). HotSpot的对 ...

  2. 【转载】C#中List集合中Last和LastOrDefault方法的差别

    在C#的List集合操作中,Last方法和LastOrDefault方法都会用来查找集合中最后一个符合条件的元素对象,但Last和LastOrDefault方法还是有差别的,建议使用LastOrDef ...

  3. security Alternative forms secuerity

    security Alternative forms secuerity (mostly obsolete) English Alternative forms secuerity Pronuncia ...

  4. 离线安装Kubernetes

    离线安装Kubernetes 环境准备: systemctl stop firewalld systemctl disable firewalld ​ 关闭selinux ​ sed -i 's/^S ...

  5. MAC地址IP地址网关地址

    MAC地址与IP地址区别 IP地址和MAC地址相同点是它们都唯一,不同的特点主要有: 对于网络上的某一设备,如一台计算机或一台路由器,其IP地址是基于网络拓扑设计出的,同一台设备或计算机上,改动IP地 ...

  6. pdsh工具的使用

    pdsh的全称是parallel distributed shell,与pssh类似,pdsh可并行执行对远程目标主机的操作,在有批量执行命令或分发任务的运维需求时,使用这个命令可达到事半功倍的效果. ...

  7. ES6--默认参数表达式,参数变动

    今天发现个有趣的问题,传入默认参数是个函数时,自定义参数回变动. 先上例子再说 let value = 5; function getValue() { return value++; } funct ...

  8. 《TensorFlow2深度学习》学习笔记(四)对笔记二中的模型增加正确率展示

    全部代码如下:(红色部分为与笔记二不同之处) #1.Import the neccessary libraries needed import numpy as np import tensorflo ...

  9. X2E车载数据记录仪

            随着智能驾驶及网联技术深入应用,汽车中传输的数据量与日俱增,包括多种总线数据.视频数据.雷达数据.定位数据等等.据悉,高级别智能驾驶汽车中每秒传输的总线数据就达到G比特级别.而从产品开 ...

  10. ACAG 0x01-4 最短Hamilton路径

    ACAG 0x01-4 最短Hamilton路径 论为什么书上标程跑不过这道题-- 首先,这道题与今年CSP-S2的D1T3有着异曲同工之妙,那就是--都有$O(n!)$的做法!(大雾) 这道题的正解 ...