LINK:Multiple Testcases

得到很多种做法。其中O(n)的做法值得一提。

容易想到二分答案 check的时候发现不太清楚分配的策略。

需要先考虑如何分配 容易发现大的东西会对小的产生影响 而 对于某个能放的位置 我们放大的一定比小的要优。所以为了防止出现对小的影响到了需要调整的局面和放大的的局面不会比放小的差的思想 可以得到策略。

有了贪心的思路 可以考虑先放大的 考虑对于每个桶中从大到小放。

放完一个数字之和容易二分到下一个位置 然后set取出相应的值即可。复杂度nlogn.

容易发现其实不需要二分 预处理一下跳跃数组即可。

这个做法有另外的形式 sort一下从大到小放 然后发现位置不够用的时候再开一个 用堆或者set维护能用的位置。复杂度还是nlogn.

接下来考虑二分答案的思路。

一个比较不容易想到是正确的分配思路 二分答案之后 如果答案合法那么按照 1...mid ->1,,,mid放一定可以合法。

换句话说 答案满足这样构造的情况。设\(a_i\)为每个数字的个数\(g_i=\sum{w=i}^ka_w\)\(c_i\)表示限制

证明:如果mid>=ans 那么必然满足 \(mid\geq max{\lceil \frac{g_i}{c_i}\rceil}\)

这个结论是显然的。而这样构造可以发现对于某个i和其之后的数字来说算是平均分配了给了mid.

而这样平均分又有上述的关系作为保证 所以构造合法。

至此 进一步的 可以发现答案直接为上述式子的最大值即可。复杂度O(n)

code nlogn的set:

const ll MAXN=200010;
ll n,m,ans;
int c[MAXN],vis[MAXN];
vector<int>g[MAXN];
multiset<int>s;
multiset<int>:: iterator it;
signed main()
{
//freopen("1.in","r",stdin);
get(n);get(m);
rep(1,n,i)
{
int get(x);
s.insert(x);
}
c[0]=INF;
rep(1,m,i)get(c[i]),c[i]=min(c[i-1],c[i]);
int cnt=0;
while(cnt<n)
{
++ans;
it=s.end();--it;
int R=*it;
int ww=0;
while(1)
{
++ww;++cnt;
g[ans].pb(R);
if(cnt==n)break;
s.erase(it);
int l=0,r=R;
while(l+1<r)
{
int mid=(l+r)>>1;
if(c[mid]>ww)l=mid;
else r=mid;
}
int cc=c[r]>ww?r:l;
R=cc;
if(!R)break;
it=s.upper_bound(R);
if(it==s.begin())break;
--it;R=*it;
}
}
put(ans);
rep(1,ans,i)
{
printf("%d ",g[i].size());
for(ui j=0;j<g[i].size();++j)printf("%d ",g[i][j]);
puts("");
}
return 0;
}

O(n)的构造

const int MAXN=200010;
int n,m,ans;
int c[MAXN],w[MAXN],a[MAXN];
vector<int>g[MAXN];
signed main()
{
freopen("1.in","r",stdin);
get(n);get(m);
rep(1,n,i)++a[read()];
rep(1,m,i)get(c[i]);
fep(m,1,i)w[i]=a[i]+w[i+1],ans=max(ans,(w[i]-1)/c[i]+1);
int cnt=0;
rep(1,m,i)while(a[i])g[cnt].pb(i),cnt=(cnt+1)==ans?0:cnt+1,--a[i];
put(ans);
rep(0,ans-1,i)
{
printf("%d ",g[i].size());
for(ui j=0;j<g[i].size();++j)printf("%d ",g[i][j]);
puts("");
}
return 0;
}

EC R 86 D Multiple Testcases 构造 贪心 二分的更多相关文章

  1. Codeforces Round #768 (Div. 2) D. Range and Partition // 思维 + 贪心 + 二分查找

    The link to problem:Problem - D - Codeforces   D. Range and Partition  time limit per test: 2 second ...

  2. The 14th Zhejiang Provincial Collegiate Programming Contest Sponsored by TuSimple - F 贪心+二分

    Heap Partition Time Limit: 2 Seconds      Memory Limit: 65536 KB      Special Judge A sequence S = { ...

  3. 贪心/二分查找 BestCoder Round #43 1002 pog loves szh II

    题目传送门 /* 贪心/二分查找:首先对ai%=p,然后sort,这样的话就有序能使用二分查找.贪心的思想是每次找到一个aj使得和为p-1(如果有的话) 当然有可能两个数和超过p,那么an的值最优,每 ...

  4. poj 2782 Bin Packing (贪心+二分)

    F - 贪心+ 二分 Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu   Description ...

  5. Card Game Cheater(贪心+二分匹配)

    Card Game Cheater Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others ...

  6. Codeforces Round #301 (Div. 2) B. School Marks 构造/贪心

    B. School Marks Time Limit: 1 Sec  Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/540/probl ...

  7. LA 6979 Known Notation 构造+贪心 铜牌题

    题意:给出一个字符串,有两种操作: 1.插入一个数字  2.交换两个字符   问最少多少步可以把该字符串变为一个后缀表达式(操作符只有*) #include <cstdio> #inclu ...

  8. Codeforces 985 最短水桶分配 沙堆构造 贪心单调对列

    A B /* Huyyt */ #include <bits/stdc++.h> #define mem(a,b) memset(a,b,sizeof(a)) #define mkp(a, ...

  9. 2020牛客暑期多校训练营 第二场 C Cover the Tree 构造 贪心

    LINK:Cover the Tree 最受挫的是这道题,以为很简单 当时什么都想不清楚. 先胡了一个树的直径乱搞的贪心 一直过不去.后来意识到这类似于最经典长链剖分优化贪心的做法 然后那个是求最大值 ...

随机推荐

  1. Xor_Sum 题解

    题目 You are given a positive integer \(N(1≦N≦10^{18})\). Find the number of the pairs of integers \(u ...

  2. C# 基于内容电影推荐项目(一)

    从今天起,我将制作一个电影推荐项目,在此写下博客,记录每天的成果. 其实,从我发布 C# 爬取猫眼电影数据 这篇博客后, 我就已经开始制作电影推荐项目了,今天写下这篇博客,也是因为项目进度已经完成50 ...

  3. 二叉树的深度(剑指offer-38)

    题目描述 输入一棵二叉树,求该树的深度.从根结点到叶结点依次经过的结点(含根.叶结点)形成树的一条路径,最长路径的长度为树的深度. 递归解析: 思路: 从根节点出发,查询左子树的深度,获取右子树的深度 ...

  4. django 本地项目部署uwsgi 以及云服务器部署 uwsgi+Nginx+Docker+MySQL主从

    一 .django 本地项目部署uwsgi 1 本地部署项目 uwsgi安装测试 通过uwsgi 进行简单部署 安装uwsgi命令:pip install uwsgi -i http://pypi.d ...

  5. 【XCTF】Cat

    标签:宽字节.PHP.Django.命令执行 解题过程 目录扫描没有发现任何可疑页面. 测试输入许多域名,均没有反应:输入ip地址得到回显. 猜测为命令执行,尝试使用管道符拼接命令. 测试:|.&am ...

  6. Scala 面向对象(八):特质(接口) 一

    1 Scala接口的介绍 从面向对象来看,接口并不属于面向对象的范畴,Scala是纯面向对象的语言,在Scala中,没有接口. Scala语言中,采用特质trait(特征)来代替接口的概念,也就是说, ...

  7. AI开发利器:HiLens Studio技术解读

    摘要:传统的AI应用开发和部署意味着高成本和高门槛,借助HiLens Studio,AI应用开发和部署仅需要三步. 曾几何时, 在我们青春年少时, 当我们看到某篇AI的技术文章时, 心中总不免想要在一 ...

  8. SpringMVC中@RequestBody接收前端传来的多个参数

    在使用ajax发送请求时,如果发送的JSON数据是一个类中的不同属性,在Controller方法中使用@RequestBody会直接封装进该类中 例如: 前端部分代码 JavaScript <s ...

  9. Spring Boot整合swagger使用教程

    目录 Swagger的介绍 优点与缺点 添加swagger 1.添加依赖包: 2.配置Swagger: 3.测试 场景: 定义接口组 定义接口 定义接口请求参数 场景一:请求参数是实体类. 场景二:请 ...

  10. java大数据最全课程学习笔记(3)--HDFS 简介及操作

    目前CSDN,博客园,简书同步发表中,更多精彩欢迎访问我的gitee pages 目录 HDFS 简介及操作 HDFS概述 HDFS产出背景及定义 HDFS优缺点 HDFS组成架构 HDFS文件块大小 ...