BZOJ4124 : [Baltic2015]Tug of war
建立二分图,首先如果存在度数为$0$的点,那么显然无解。
如果存在度数为$1$的点,那么这个点的匹配方案固定,可以通过拓扑排序去掉所有这种点。
那么现在剩下的点度数都至少为$2$,因为左右点数相等,且左边每个点度数都是$2$,所以右边只能是每个点的度数都是$2$。
在这种情况下每个连通块是一个环,相邻两条边不能同时选,一共有两种情况$x$和$y$。
假设$x\leq y$,那么把$x$加入$sum$,$y-x$既可以加入,又可以不加入,对$y-x$进行01背包即可。
注意到本题中物品数不超过$2n$,物品价值之和不超过$2k\leq 40n$。
所以将01背包转化为多重背包后只有$O(\sqrt{k})$种物品,二进制拆分+bitset优化即可。
时间复杂度$O(\frac{k\sqrt{k}\log k}{64})$。
- #include<cstdio>
- #include<bitset>
- #include<algorithm>
- using namespace std;
- const int N=120010,M=1200010;
- int n,m,K,i,j,k,x,y,z,g[N],v[N<<1],w[N<<1],nxt[N<<1],ed,d[N],h,t,q[N],vis[N],sum,cnt[M];
- bitset<M>f;
- inline void read(int&a){char c;while(!(((c=getchar())>='0')&&(c<='9')));a=c-'0';while(((c=getchar())>='0')&&(c<='9'))(a*=10)+=c-'0';}
- inline void add(int x,int y,int z){
- d[x]++,d[y]++;
- v[++ed]=y;w[ed]=z;nxt[ed]=g[x];g[x]=ed;
- v[++ed]=x;w[ed]=z;nxt[ed]=g[y];g[y]=ed;
- }
- inline int go(int x){
- for(int i=g[x];i;i=nxt[i])if(!vis[v[i]])return v[i];
- return 0;
- }
- inline int get(int x,int y){for(int i=g[x];i;i=nxt[i])if(v[i]==y)return w[i];}
- int main(){
- read(n),read(K);m=n+n;
- for(i=1;i<=m;i++){
- read(x),read(y),read(z);
- add(i,x+m,z);
- add(i,y+n+m,-z);
- }
- m<<=1;
- for(i=1;i<=m;i++)if(!d[i])return puts("NO"),0;
- for(h=i=1;i<=m;i++)if(d[i]==1)q[++t]=i;
- while(h<=t){
- for(i=g[x=q[h++]];i;i=nxt[i])if(!vis[v[i]]){
- y=v[i];
- sum+=w[i];
- break;
- }
- vis[x]=vis[y]=1;
- for(i=g[y];i;i=nxt[i])if(!vis[x=v[i]]){
- if(!(--d[x]))return puts("NO"),0;
- if(d[x]==1)q[++t]=x;
- }
- }
- for(n=0,i=1;i<=m;i++)if(!vis[i]){
- vis[q[t=1]=i]=1;
- for(j=go(i);j;j=go(j))vis[q[++t]=j]=1;
- q[t+1]=q[1];
- x=y=0;
- for(j=1;j<=t;j+=2)x+=get(q[j],q[j+1]);
- for(j=2;j<=t;j+=2)y+=get(q[j],q[j+1]);
- if(x>y)swap(x,y);
- sum+=x;
- cnt[y-x]++;
- n=max(n,y-x);
- }
- for(f[0]=i=1;i<=n;i++)for(j=1;cnt[i];j<<=1){
- k=min(cnt[i],j);
- cnt[i]-=k;
- f|=f<<(i*k);
- }
- for(i=-K;i<=K;i++)if(i-sum>=0&&i-sum<M)if(f[i-sum])return puts("YES"),0;
- return puts("NO"),0;
- }
BZOJ4124 : [Baltic2015]Tug of war的更多相关文章
- HDU-2576 Tug of War
http://poj.org/problem?id=2576 二维数组01背包的变形. Tug of War Time Limit: 3000MS Memory Limit: 65536K Tot ...
- 随机算法 poj 2576 Tug of War
Tug of War Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 8187 Accepted: 2204 Descri ...
- UVA - 10032 Tug of War (二进制标记+01背包)
Description Problem F: Tug of War A tug of war is to be arranged at the local office picnic. For the ...
- uva 10032 Problem F: Tug of War
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- zoj 1880 - Tug of War
题目:有n个人分成两组,两组人数差不能超过1,找到两组的人重量之差的最小值. 分析:dp,二维01背包. 由于必须放在两个组中的一组,直接背包全部可到状态, 取出相差不超过 1的最接近 sum/2的值 ...
- POJ2576 Tug of War 二维背包
题目大意 一群人拔河,给出每个人的重量,要求两队人数之差不超过1人,且每队总重量之差最小. 思路 选出严格总人数一半(或+1)的人为一队,在该队重量不超过所有人总重量一半的情况下,使其重量最大. 人数 ...
- poj 2576 Tug of War
还是神奇的随机算法,,(看视频说这是爬山法??) 其实就是把序列随机分成两半(我太弱,只知道random_shuffle),然后再每个序列里rand一个位置,x,y然后比较是不是交换之后是更优的. 然 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- 动态规划:POJ2576-Tug of War(二维费用的背包问题)
Tug of War Time Limit: 3000MS Memory Limit: 65536K Description A tug of war is to be arranged at the ...
随机推荐
- centos系统初始化流程及实现系统裁剪
Linux系统的初始化流程: POST:ROM+RAM BIOS: Boot Sequence MBR: 446:bootloader 64: 分区表 2: 5A kernel文件:基本磁盘分区 /s ...
- Android:Camera
Android Camera开发 Android手机关于Camera的使用,一是拍照,二是摄像,由于Android提供了强大的组件功能,为此对于在Android手机系统上进行Camera的开发,我们可 ...
- PYTHON-流程控制之if/while/for
内容: 流程控制: 1. if 2. while 3. for ==================================流程控制之if判断 1 什么是if判断 判断一个条件如果成立则做.. ...
- PYTHON-模块定义 搜索路径
模块是什么: ***** 模块 是一系列功能的集合体 一个py文件就是一个模块 一个函数就是一个功能 例如 A.py 文件名A.py 模块名 A 模块有哪些来源 内置 第三方 自定义 模块有四种通用的 ...
- 【python】正则表达式中的转义问题
encode('string-escape') 解决 比如想匹配'\x0e\x0a'中的'\x'后的内容,这里希望把'\x0e'作为一个字符串,那么其中的\应该被转义. 未加转义的正则: p = '( ...
- poj1742 多维背包
普通的多维背包做不了,需要优化一下 但是没有学优化..别的方法也是可以做的 省去一个 表示阶段的 i 维度,dp[j]表示面值为j的钱是否被凑出来了,used[j]表示第i种硬币在凑面值为j的时候被用 ...
- 【C++ Primer | 15】C++虚函数表剖析②
多重继承 下面,再让我们来看看多重继承中的情况,假设有下面这样一个类的继承关系. 注意:子类只overwrite了父类的f()函数,而还有一个是自己的函数(我们这样做的目的是为了用g1()作为一个标记 ...
- Hibernate的核心对象关系映射
Hibernate的核心就是对象关系映射: 加载映射文件的两种方式: 第一种:<mapping resource="com/bie/lesson02/crud/po/employee. ...
- Struts2的常见的配置文件介绍
1:package 定义一个包. 包作用,管理action. (通常,一个业务模板用一个包) 常见属性及其说明: (1)name 包的名字:以方便在其他处引用此包,此属性是必须的. 包名不能重复: ...
- java -d
DB_SERVER_URL="-Ddatasource.driver=oracle.jdbc.OracleDriver -Ddatasource.url=jdbc:oracle:thin:@ ...