【BZOJ2400】Optimal Marks
题意
定义无向图中的一条边的值为:这条边连接的两个点的值的异或值。
定义一个无向图的值为:这个无向图所有边的值的和。
给你一个有 \(n\) 个结点 \(m\) 条边的无向图。其中的一些点的值是给定的,而其余的点的值由你决定(但要求均为非负数),使得这个无向图的值最小。在无向图的值最小的前提下,使得无向图中所有点的值的和最小。
题解
对每一位单独考虑。对于已经确定的数,如果当前位是 \(0\) 则与起点连边,为 \(1\) 则与终点连边,然后原图上的边容量为 \(1\) 的边。这样对于未知的点我们选择是 \(0\) 还是 \(1\) ,就要把连到另一个集合的边给砍掉,我们最小化砍掉的边,即求最小割。
求第二个答案也很好求,我们直接 dfs 求出哪些点属于 \(T\) 集合即可。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
inline int gi()
{
char c; int x=0,f=1;
for(;c<'0'||c>'9';c=getchar())if(c=='-')f=-1;
for(;c>='0'&&c<='9';c=getchar())x=(x<<1)+(x<<3)+c-'0';
return x*f;
}
typedef long long ll;
const int N=505,M=20005,inf=1<<30;
int head[N],nxt[M],to[M],wei[M],lev[N],q[N],tot=1,n,m,s=1,t,u[M],v[M],w[N];
bool vis[N];
ll ans1,ans2,nw[N];
void addedge(int u, int v, int w) {
nxt[++tot]=head[u],head[u]=tot,to[tot]=v,wei[tot]=w;
nxt[++tot]=head[v],head[v]=tot,to[tot]=u,wei[tot]=0;
}
bool bfs()
{
memset(lev,-1,sizeof(lev));
int l=0,r=0;
q[0]=s; lev[s]=1;
while(l<=r)
{
int u=q[l++];
for(int e=head[u];e;e=nxt[e])
if(lev[to[e]]==-1&&wei[e])
{
lev[to[e]]=lev[u]+1;
if(to[e]==t) return true;
q[++r]=to[e];
}
}
return false;
}
int dfs(int u, int mx)
{
if(u==t) return mx;
int l=mx;
for(int e=head[u];e&&l;e=nxt[e])
if(lev[to[e]]==lev[u]+1&&wei[e]>0)
{
int f=dfs(to[e],min(l,wei[e]));
if(!f) lev[to[e]]=-1;
l-=f,wei[e]-=f,wei[e^1]+=f;
}
return mx-l;
}
void vist(int u)
{
vis[u]=true;
for(int e=head[u];e;e=nxt[e])
if(!vis[to[e]]&&wei[e^1]) vist(to[e]);
}
int main()
{
#ifndef ONLINE_JUDGE
freopen("1919.in","r",stdin);
#endif
n=gi(),m=gi();
s=n+1,t=n+2;
for(int i=1;i<=n;++i) w[i]=gi();
for(int i=1;i<=m;++i) u[i]=gi(),v[i]=gi();
for(int i=0;i<=30;++i)
{
memset(head,0,sizeof(head)),tot=1;
memset(vis,false,sizeof(vis));
for(int j=1;j<=n;++j)
if(w[j]>=0)
{
if(w[j]&(1<<i)) addedge(j,t,inf);
else addedge(s,j,inf);
}
for(int j=1;j<=m;++j) addedge(u[j],v[j],1),addedge(v[j],u[j],1);
int tmp=0; while(bfs()) tmp+=dfs(s,inf);
ans1+=1ll*tmp*(1<<i);
vist(t);
for(int j=1;j<=n;++j) if(vis[j]) nw[j]+=(1<<i);
}
printf("%lld\n",ans1);
for(int i=1;i<=n;++i) w[i]<0?ans2+=nw[i]:ans2+=w[i];
printf("%lld",ans2);
}
【BZOJ2400】Optimal Marks的更多相关文章
- 【BZOJ-2400】Spoj839Optimal Marks 最小割 + DFS
2400: Spoj 839 Optimal Marks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 567 Solved: 202[Submit ...
- 【SPOJ839】Optimal Marks 网络流
You are given an undirected graph G(V, E). Each vertex has a mark which is an integer from the range ...
- 【BZOJ2400】Spoj 839 Optimal Marks 最小割
[BZOJ2400]Spoj 839 Optimal Marks Description 定义无向图中的一条边的值为:这条边连接的两个点的值的异或值. 定义一个无向图的值为:这个无向图所有边的值的和. ...
- 【bzoj2400】Spoj 839 Optimal Marks 按位最大流
Spoj 839 Optimal Marks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 908 Solved: 347[Submit][Stat ...
- 【USACO】Optimal Milking
题目链接 : [POJ]点击打开链接 [caioj]点击打开链接 算法 : 1:跑一遍弗洛伊德,求出点与点之间的最短路径 2:二分答案,二分”最大值最小“ 3.1:建边,将 ...
- 【bzoj2400】Spoj 839 Optimal Marks 网络流最小割
题目描述 定义无向图中的一条边的值为:这条边连接的两个点的值的异或值. 定义一个无向图的值为:这个无向图所有边的值的和. 给你一个有n个结点m条边的无向图.其中的一些点的值是给定的,而其余的点的值由你 ...
- 【poj2122】 Optimal Milking
http://poj.org/problem?id=2112 (题目链接) 题意 有K个能挤M头奶牛的挤奶机和C头奶牛,告诉一些挤奶机和奶牛间距离,求最优分配方案使最大距离最小. Solution 先 ...
- 【LeetCode】数学(共106题)
[2]Add Two Numbers (2018年12月23日,review) 链表的高精度加法. 题解:链表专题:https://www.cnblogs.com/zhangwanying/p/979 ...
- 【LeetCode】字符串 string(共112题)
[3]Longest Substring Without Repeating Characters (2019年1月22日,复习) [5]Longest Palindromic Substring ( ...
随机推荐
- python 中的 *args 和 **kwargs
在阅读Python代码时,经常会看到如下函数的定义: def fun(*args, **kwargs): 很多同学可能会对此感到困惑,这个 * args和 **kwargs是什么东西.为啥会在源码中应 ...
- AI算法工程师炼成之路
AI算法工程师炼成之路 面试题: l 自我介绍/项目介绍 l 类别不均衡如何处理 l 数据标准化有哪些方法/正则化如何实现/onehot原理 l 为什么XGB比GBDT好 l 数据清洗的方法 ...
- GoJS组织结构图2
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- CSP-S2019 爆炸记
DAY -1 停课的第五天.早上来机房教练居然不在,先看了一道憨题,发现ST表+二分查找nlogn水过,然后发现单调栈可以O(n),肥肠开心 打了走人. 然后就开始颓了(逃 颓了一会之后看愤怒的小鸟这 ...
- PyQt5点击菜单栏弹出新窗口,解决新窗口闪退的实现方法
实现的功能为:当点击菜单中某个菜单时,会弹出一个新窗口,下面就列出部分代码 def mail_setting(self): log.debug("open mail settings&quo ...
- 收藏了一篇很有用的博客 “npm的安装教程”
暂时贴上这一篇博客的地址,感谢原作者 https://www.cnblogs.com/goldlong/p/8027997.html 使用之前,我们先来掌握3个东西是用来干什么的. npm: Node ...
- HiBench成长笔记——(2) CentOS部署安装HiBench
安装Scala 使用spark-shell命令进入shell模式,查看spark版本和Scala版本: 下载Scala2.10.5 wget https://downloads.lightbend.c ...
- 云时代架构阅读笔记十一——数据库SQL优化
网上关于SQL优化的教程很多,但是比较杂乱.近日有空整理了一下,写出来跟大家分享一下,其中有错误和不足的地方,还请大家纠正补充. 1.对查询进行优化,要尽量避免全表扫描,首先应考虑在 where 及 ...
- windows清理命令
总是有一些设备需要清理,第三方的软件有不可以安装,那么,就需要这两条命令来做: cleanmgr /sageset:99 #设置要被清理的东西 cleanmgr /sagerun:99 #执行清理操作 ...
- ionic实现滑动的三种方式
在移动端受屏幕大小所限,展示内容很多的时候,就要使部分区域进行滑动.本文展示项目中所有到的几种方式,大家可以看自己的需求选择合适的滑动方式.实现滑动的基本原理,有两个容器A.B,假如A在外层,B在内层 ...