热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Codeforces1242CSumBalance——状压+爆搜

Thisway题意:给你k个数组,每个数组有ni个数,每个数只会出现一次。现在要将每一个数组中拿出一个数放到任意一个数组中࿰

This way

题意:

给你k个数组,每个数组有ni个数,每个数只会出现一次。现在要将每一个数组中拿出一个数放到任意一个数组中,并且使得每个数组的数量保持不变。问你每个数组要拿出去的数以及放到哪个数组中

题解:

我是想用状压dp做来着。。但是那样子要保存每个环的信息所以太麻烦了
那么由于每个数只会出现一次,所以对于每个数组的每个数拿出去之后,都会有一个唯一的数补上来。所以我们dfs当前在那个数组以及当前取的环包含的状态,如果当前行不在状态中,那么枚举当前行包含的每一个数,查看取出这个数所能找到的环,继续向下搜

#include
using namespace std;
#define ll long long
const int N=5e4+5;
int n[16],a2[16],k;
ll a[16][N],sum[16],ave,a1[16];
unordered_mapmp;
unordered_mapvis;
int finds(int x,ll val,int s){int now&#61;x;ll v&#61;val;s|&#61;(1<}
void dfs(int x,int s){if(x>k){printf("Yes\n");for(int i&#61;1;i<&#61;k;i&#43;&#43;)printf("%lld %d\n",a1[i],a2[i]);exit(0);}if(vis[s])return ;if(s&(1<}
int main()
{scanf("%d",&k);for(int i&#61;1;i<&#61;k;i&#43;&#43;){scanf("%d",&n[i]);for(int j&#61;1;j<&#61;n[i];j&#43;&#43;){scanf("%lld",&a[i][j]);sum[i]&#43;&#61;a[i][j],ave&#43;&#61;a[i][j];mp[a[i][j]]&#61;i;}}if(ave%k)return 0*printf("No\n");ave/&#61;k;dfs(1,0);printf("No\n");return 0;
}


推荐阅读
  • 题面:P3178[HAOI2015]树上操作好像其他人都嫌这道题太容易了懒得讲,好吧那我讲。题解:第一个操作和第二个操作本质上是一样的&# ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • 本文介绍了一种使用链剖分(Link-Cut Tree, LCT)来维护动态树结构的方法,特别是如何通过 LCT 来高效地管理子树的信息,如子树大小等。 ... [详细]
  • 本文针对HDU 1042 N! 问题提供详细的解析和代码实现。题目要求计算给定整数N(0 ≤ N ≤ 10000)的阶乘N!。文章不仅提供了算法思路,还附上了C++语言的具体实现。 ... [详细]
  • 本文详细探讨了HihoCoder平台上的1398号问题——最大权闭合子图的求解方法。通过具体实例,深入分析了最大权闭合子图的概念及其算法实现。 ... [详细]
  • HDU 2537 键盘输入处理
    题目描述了一个名叫Pirates的男孩想要开发一款键盘输入软件,遇到了大小写字母判断的问题。本文提供了该问题的解决方案及实现方法。 ... [详细]
  • 本题旨在通过实现矩阵加法,加深对多维数组的理解。题目要求读取两个 n×m 的矩阵 A 和 B,并计算它们的和。 ... [详细]
  • 本文详细探讨了select和epoll两种I/O多路复用技术的内部实现原理,分析了它们在处理大量文件描述符时的性能差异,并通过具体示例代码展示了select的工作流程。 ... [详细]
  • UVa 11683: 激光雕刻技术解析
    自1958年发明以来,激光技术已在众多领域得到广泛应用,包括电子设备、医疗手术工具、武器等。本文将探讨如何使用激光技术进行材料雕刻,并通过编程解决一个具体的激光雕刻问题。 ... [详细]
  • 在学习了Splay树的基本查找功能后,可能会觉得它与普通的二叉查找树没有太大的区别,仅仅是通过splay操作减少了时间开销。然而,Splay树之所以被誉为“序列之王”,主要在于其强大的区间操作能力。 ... [详细]
  • 本文介绍了一个来自AIZU ONLINE JUDGE平台的问题,即清洁机器人2.0。该问题来源于某次编程竞赛,涉及复杂的算法逻辑与实现技巧。 ... [详细]
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • 本文探讨了Linux环境下线程私有数据(Thread-Specific Data, TSD)的概念及其重要性,介绍了如何通过TSD技术避免多线程间全局变量冲突的问题,并提供了具体的实现方法和示例代码。 ... [详细]
  • 【MySQL】frm文件解析
    官网说明:http:dev.mysql.comdocinternalsenfrm-file-format.htmlfrm是MySQL表结构定义文件,通常frm文件是不会损坏的,但是如果 ... [详细]
  • 探讨了一个包含纯虚函数的C++代码片段,分析了其中的语法错误及逻辑问题,并提出了修正方案。 ... [详细]
author-avatar
hanliu46460
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有