【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

一开始所有的数字单独成一个集合。
然后用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的更多相关文章

  1. 【Henu ACM Round#20 F】 Arthur and Brackets

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 所给的li,ri是左括号从左到右的顺序给的. (且注意长度是2*n 现在我们先把第一个左括号放在第1个位置. 然后考虑第二个位置. ...

  2. 【Henu ACM Round#20 E】Star

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 找规律. 1,13,37.... 6n(n-1) + 1 [代码] #include <bits/stdc++.h> # ...

  3. 【Henu ACM Round#20 C】 Eevee

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 处理处所有的字符串可能的样子. 存在map里面就好. [代码] #include <bits/stdc++.h> usi ...

  4. 【Henu ACM Round#20 B】Contest

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 根据时间和原分数. 算出对应的分数就可以了. [代码] #include <bits/stdc++.h> using n ...

  5. 【Henu ACM Round#20 A】 Fancy Fence

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 看看有没有(n-2)*180/n等于输入的a就好. [代码] #include <bits/stdc++.h> usin ...

  6. 【Henu ACM Round#15 F】Arthur and Questions

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] a1+a2+...+ak<a2+a3+...ak+1 ->a1<ak+1 a2+a3+...+ak+1<a3 ...

  7. 【Henu ACM Round#24 E】Connected Components

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 要求把连续的一段li..ri的边全都删掉. 然后求剩下的图的联通数 如果暴力的话 复杂度显然是O(k*m)级别的. 考虑我们把li. ...

  8. 【Henu ACM Round#24 D】Iterated Linear Function

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把B提取出来就是一个等比数列了. 求和一下会发现是这种形式. \(B*\frac{(A^n-1)}{A-1}+A^n*x\) 则求一 ...

  9. 【Henu ACM Round#24 C】Quiz

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 肯定是这样 先放k-1个,然后空1个,然后再放k-1个.然后再空1个.. 以此类推. 然后如果(n/k)*(k-1)+n%k> ...

随机推荐

  1. 《汇编语言(第三版)》pushf 和 popf 指令,以及标志寄存器在 Debug 中的表示

    pushf 和 popf pushf 的功能是将标志寄存器的值压栈,而 popf 是从栈中弹出数据,输入标志寄存器. pushf 和 popf,为直接访问寄存器提供了方法. 格式 pushf popf ...

  2. vmware workstation pro 14 虚拟机无法开启、黑屏的解决方案汇总

    方案1:卸载鲁大师,重启. 方案2:管理员命令行,输入netsh winsock reset,重启. 方案3:360安全管家修复LSP,重启. 方案4:卸载14.0,安装12.0,手动导入虚拟机.

  3. Intellij IDEA安装与使用,完整详细。

    https://blog.csdn.net/qq_41879385/article/details/81952656 https://www.jetbrains.com/idea/download/# ...

  4. swift语言点评十七-Designated Initializers and Convenience Initializers

    Swift defines two kinds of initializers for class types to help ensure all stored properties receive ...

  5. SpringBoot 获取客户端 ip

    /** * 获取客户端ip地址 * @param request * @return */ public static String getCliectIp(HttpServletRequest re ...

  6. CF1005F Berland and the Shortest Paths (树上构造最短路树)

    题目大意:给你一个边权为$1$的无向图,构造出所有$1$为根的最短路树并输出 性质:单源最短路树上每个点到根的路径 ,一定是这个点到根的最短路之一 边权为$1$,$bfs$出单源最短路,然后构建最短路 ...

  7. ansible搭建mysql主主模式

    ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric)等优点,实现了批量系统配置.批量程序部署.批量运行命 ...

  8. 关于JWT(Json Web Token)的思考及使用心得

    什么是JWT? JWT(Json Web Token)是一个开放的数据交换验证标准rfc7519(php 后端实现JWT认证方法一般用来做轻量级的API鉴权.由于许多API接口设计是遵循无状态的(比如 ...

  9. [Java] 使用 Apache的 Commons-net库 实现FTP操作

    因为最近工作中需要用到FTP操作,而手上又没有现成的FTP代码.就去网上找了一下,发现大家都使用Apache的 Commons-net库中的FTPClient. 但是,感觉用起来不太方便.又在网上找到 ...

  10. iOS - 自己定义alertView,继承自UIView,能够加入子视图,标题图片+文字

    这个更简单,能够看下demo       https://github.com/DYLAN-LWB/WBAlertView 自己定义alertView,继承自UIView,能够在消息区域加入子视图:a ...