【Henu ACM Round#20 D】 Devu and Partitioning of the Array
【链接】 我是链接,点我呀:)
【题意】
在这里输入题意
【题解】
一开始所有的数字单独成一个集合。
然后用v[0]和v[1]记录**集合的和**为**偶数**和**奇数**的集合**它们的根节点**(并查集
然后先让v[0]的大小变成p
//奇数+偶数是奇数
//奇数+奇数是偶数
//偶数+偶数是偶数
如果v[0].size < p
那么随便让两个和为奇数的集合,让他们合并在一起,加入到偶数集合中,那么v[0].size++,v[1].size-=2了
如果v[0].size > p
那么有两种方法
1.让两个偶数集合合并在一起,变成一个更大的偶数集合,v[0].size()--
2.让一个偶数集合和一个奇数集合合并在一起,变成一个奇数集合,v[0].size()--,但是奇数集合个数还是不变
此后v[0].size==p了
那么接下来只要调整v[1].size就好了
但是在调整之前先判断v[0].size()+v[1].size()>=k是否成立
如果小于k的话,是肯定没办法变多的。
因为越并只能越少的
然后如果大于k的话,只能把v[1]的大小变小了。
根据上面奇数和偶数相加的规则。
不难发现。
只能把两个奇数合并成偶数才能减少奇数的个数。
且显然奇数只能两个两个地减少。
减少的过程如下
1.把两个奇数合并成1个偶数。
2.把新合成的那个偶数去掉
有两种去掉的方法
①用两个偶数集合合成一个新的偶数集合
②再用一个奇数和这个偶数,合成一个奇数集合
最后看看v[0].size()+v[1].size()是否等于k就好。
最后根据并查集的根节点。
输出每个集合里面的元素就好。
【代码】
#include <bits/stdc++.h>
using namespace std;
//������������ж��ٸ���ż���ж��ٸ�
//����+ż��������
//����+������ż��
//ż��+ż����ż��
//������û��p��ż��
//���û�еĻ�
// ����������һ��ż��
const int N = 1e5;
int n,k,p;
int f[N+10],a[N+10];
vector<int> v[2];
vector<int> bo[N+10];
int ff(int x){
if (f[x]==x)
return x;
else
return f[x] = ff(f[x]);
}
int qu(int idx){
int x = v[idx].back();
v[idx].pop_back();
return x;
}
int main()
{
ios::sync_with_stdio(0),cin.tie(0);
cin >> n >> k >> p;
for (int i = 1;i <= n;i++){
cin >> a[i];
v[a[i]%2].push_back(i);
}
for (int i = 1;i <= n;i++) f[i] = i;
while ((int)v[0].size()<p){
if ((int)v[1].size()>=2){
int x = qu(1),y = qu(1);
int r1 = ff(x),r2 = ff(y);
f[r1] = r2;
v[0].push_back(r2);
}else{
return cout<<"NO"<<endl,0;
}
}
//a[0] >= p
while ((int)v[0].size()>p){
if ((int)v[0].size()>1){
int x = qu(0),y = qu(0);
int r1 = ff(x),r2 = ff(y);
f[r1] = r2;
v[0].push_back(r2);
continue;
}
if ((int)v[1].size()>0){
int x = qu(1);
int y = qu(0);
int r1 = ff(x),r2 = ff(y);
f[r1]=r2;
v[1].push_back(r2);
}else return cout<<"NO"<<endl,0;
}
//a[0]==p
if ((int)v[0].size()+(int)v[1].size()<k){
return cout<<"NO"<<endl,0;
}
//����+ż��������
//����+������ż��
//ż��+ż����ż��
while ((int)v[0].size()+(int)v[1].size()>k){
if ((int)v[1].size()>=2){
int x = qu(1),y = qu(1);
int r1 = ff(x),r2 = ff(y);
f[r1] = r2;
v[0].push_back(r2);
}else{
return cout<<"NO"<<endl,0;
}
if ((int)v[0].size()>1){
int x = qu(0),y = qu(0);
int r1 = ff(x),r2 = ff(y);
f[r1] = r2;
v[0].push_back(r2);
}else if ((int)v[0].size()>0 && (int)v[1].size()>0){
int x = qu(0),y = qu(1);
int r1 = ff(x),r2 = ff(y);
f[r1] = r2;
v[1].push_back(r2);
}else return cout<<"NO"<<endl,0;
}
if ((int)v[0].size()+(int)v[1].size()<k){
cout<<"NO"<<endl;
return 0;
}
cout<<"YES"<<endl;
for (int i = 1;i <= n;i++){
int r = ff(i);
bo[r].push_back(i);
}
for (int i = 1;i <= n;i++)
if (!bo[i].empty()){
cout<<(int)bo[i].size()<<' ';
for (int x:bo[i]){
cout<<a[x]<<' ';
}
cout<<endl;
}
//a[0]==p
return 0;
}
【Henu ACM Round#20 D】 Devu and Partitioning of the Array的更多相关文章
- 【Henu ACM Round#20 F】 Arthur and Brackets
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 所给的li,ri是左括号从左到右的顺序给的. (且注意长度是2*n 现在我们先把第一个左括号放在第1个位置. 然后考虑第二个位置. ...
- 【Henu ACM Round#20 E】Star
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 找规律. 1,13,37.... 6n(n-1) + 1 [代码] #include <bits/stdc++.h> # ...
- 【Henu ACM Round#20 C】 Eevee
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 处理处所有的字符串可能的样子. 存在map里面就好. [代码] #include <bits/stdc++.h> usi ...
- 【Henu ACM Round#20 B】Contest
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 根据时间和原分数. 算出对应的分数就可以了. [代码] #include <bits/stdc++.h> using n ...
- 【Henu ACM Round#20 A】 Fancy Fence
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 看看有没有(n-2)*180/n等于输入的a就好. [代码] #include <bits/stdc++.h> usin ...
- 【Henu ACM Round#15 F】Arthur and Questions
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] a1+a2+...+ak<a2+a3+...ak+1 ->a1<ak+1 a2+a3+...+ak+1<a3 ...
- 【Henu ACM Round#24 E】Connected Components
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 要求把连续的一段li..ri的边全都删掉. 然后求剩下的图的联通数 如果暴力的话 复杂度显然是O(k*m)级别的. 考虑我们把li. ...
- 【Henu ACM Round#24 D】Iterated Linear Function
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把B提取出来就是一个等比数列了. 求和一下会发现是这种形式. \(B*\frac{(A^n-1)}{A-1}+A^n*x\) 则求一 ...
- 【Henu ACM Round#24 C】Quiz
[链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 肯定是这样 先放k-1个,然后空1个,然后再放k-1个.然后再空1个.. 以此类推. 然后如果(n/k)*(k-1)+n%k> ...
随机推荐
- pugixml读取unicode编码的xml文件的做法
作者:朱金灿 来源:http://blog.csdn.net/clever101 实际上在多字节编码的情况下,即以记事本打开显示的ANSI编码的,如下图: pugixml是可以直接读取中文字符的,示例 ...
- SLAM概念学习之随机SLAM算法
这一节,在熟悉了Featue maps相关概念之后,我们将开始学习基于EKF的特征图SLAM算法. 1. 机器人,图和增强的状态向量 随机SLAM算法一般存储机器人位姿和图中的地标在单个状态向量中,然 ...
- 微信小程序------开发测试
一.注册小程序 注:微信小程序注册的邮箱不能被其他微信公众平台注册,未被微信开放平台注册,未被给人微信号绑定的微信号. 二.注册完小程序后,下载开发者工具 开发者工具的使用: 1.打开开发者工具:用已 ...
- SAI / PS绘画一个卡通女孩详解
本教程介绍使用SAI / PS绘画一个卡通女孩的教程 ,教程很详细,动起你的小手一起来试试吧! 软件下载:http://www.dongmansoft.com/xiazai.html 想要Get到更多 ...
- Hadoop_HDFS-基础知识摘要
Hadoop典型应用有:搜索.日志处理.推荐系统.数据分析.视频图像分析.数据保存等.0.数据要首先分块 Block:将一个文件进行分块,通常是64M. NameNode:--管理节点保存整个文件系统 ...
- ajax错误信息
XMLHttpRequest.status状态码 1xx-信息提示 这些状态代码表示临时的响应.客户端在收到常规响应之前,应准备接收一个或多个1xx响应. 100-继续. 101-切换协议. 2xx- ...
- python学习(二):基本数据类型:整型,字符型
整型: type():显示数据类型 # 整型,int # python3里,不管数字有多大,都是int类型 # python2里,有大小区分,长整型:long int a = " print ...
- HDU 4069 数独
好久没做题了,建图搞了好久…… 然后,判是否有多解的时候会把原来的答案覆盖掉…… 这里没注意,弄了一下午…… 代码: #include <iostream> #include <cs ...
- 三 概要模式 3) MR计数器计数 。无 reduce 计数
计数器模式讲解: 先讲一下,就是说只用 Map 阶段 不需要 Reduce . 也就是说去掉了中间输出,而是Map 直接输出结果.大大提高了 MR 的效率且节省了 MR 中间输出读入 ...
- chrome默认打开隐身模式
chrome图标右键属性,在“目标”后添加参数“ --incognito”(注意是双短划线,不包括双引号,双短划线前加一空格)就可以直接以隐身模式启动chrome了