题目大意:

给你一个无向图\(G(V,E)\)。 每个顶点都有一个int范围内的整数的标记。 不同的顶点可能有相同的标记。

对于边\((u,v)\),我们定义\(Cost(u,v)=mark [u]\ \ xor\ \ mark [v]\)。

现在我们知道某些节点的标记了。你需要确定其他节点的标记,以使边的总成本尽可能小。

最后要求输出的每个点的标号

QwQ一看到这种跟位运算有关题目,就会想到按位来处理

仔细考虑,发现这个题满足最小割的模型,对于每一位,当时将所有点的对应位分成0,或者是1

那么,我们按位来,假设当前位是\(i\),对于已经知道编号的点\(x\),如果当前位是1的话,我们\(insert(s,x,inf)\),否则\(insert(x,t,inf)\)表示,这个点是0还是1,同时inf的原因是给定的点的编号的不能改的

同时对于原图的边\(u->v\),我们只需要\(insert(u,v,1),insert(v,u,1)\) 表示这两个点的当前位是否相同,最后跑\(dinic\),剩下的残余网络中,与s相连,且沿途流量\(>0\)的,就是1,否则就是0

大致就是这样,最后千万别忘记:

1.编号可能是0

2.初始化数组

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<algorithm>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<queue>
  7. using namespace std;
  8. inline int read()
  9. {
  10. int x=0,f=1;char ch=getchar();
  11. while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}
  12. while (isdigit(ch)){x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
  13. return x*f;
  14. }
  15. const int maxn = 1010;
  16. const int maxm = 200010;
  17. const int inf = 1e9;
  18. int point[maxn],nxt[maxm],to[maxm],val[maxm];
  19. int h[maxn];
  20. int num[maxn];
  21. int ans[maxn];
  22. int x[maxm],y[maxm];
  23. int n,m,cnt=1;
  24. int s,t;
  25. int vis[maxn];
  26. queue<int> q;
  27. void addedge(int x,int y,int w){
  28. nxt[++cnt]=point[x];
  29. to[cnt]=y;
  30. val[cnt]=w;
  31. point[x]=cnt;
  32. }
  33. void init()
  34. {
  35. cnt=1;
  36. memset(point,0,sizeof(point));
  37. memset(vis,0,sizeof(vis));
  38. }
  39. void insert(int x,int y,int w)
  40. {
  41. addedge(x,y,w);
  42. addedge(y,x,0);
  43. }
  44. bool bfs(int s)
  45. {
  46. memset(h,-1,sizeof(h));
  47. h[s]=0;
  48. q.push(s);
  49. while (!q.empty())
  50. {
  51. int x = q.front();
  52. q.pop();
  53. for (int i=point[x];i;i=nxt[i])
  54. {
  55. int p = to[i];
  56. if (val[i]>0 && h[p]==-1)
  57. {
  58. h[p]=h[x]+1;
  59. q.push(p);
  60. }
  61. }
  62. }
  63. if (h[t]==-1) return false;
  64. else return true;
  65. }
  66. int dfs(int x,int low)
  67. {
  68. if (x==t || low==0) return low;
  69. int totflow=0;
  70. for (int i=point[x];i;i=nxt[i])
  71. {
  72. int p = to[i];
  73. if (val[i]>0 && h[p]==h[x]+1)
  74. {
  75. int tmp = dfs(p,min(val[i],low));
  76. val[i]-=tmp;
  77. val[i^1]+=tmp;
  78. low-=tmp;
  79. totflow+=tmp;
  80. if (low==0) return totflow;
  81. }
  82. }
  83. if (low>0) h[x]=-1;
  84. return totflow;
  85. }
  86. int dinic(){
  87. int ans=0;
  88. while (bfs(s)){
  89. ans+=dfs(s,inf);
  90. }
  91. }
  92. void dfs1(int x,int d)
  93. {
  94. vis[x]=1;
  95. ans[x]|=(1 << d);
  96. for (int i=point[x];i;i=nxt[i])
  97. {
  98. int p = to[i];
  99. if (!vis[p] &&val[i]>0)
  100. {
  101. dfs1(p,d);
  102. }
  103. }
  104. }
  105. void build(int xx)
  106. {
  107. init();
  108. s=n+10;
  109. t=s+1;
  110. for (int i=1;i<=n;i++)
  111. {
  112. if (num[i]!=-1)
  113. {
  114. if (num[i] & (1<<xx)) insert(s,i,inf);
  115. else insert(i,t,inf);
  116. }
  117. }
  118. for (int i=1;i<=m;i++)
  119. {
  120. insert(x[i],y[i],1);
  121. insert(y[i],x[i],1);
  122. }
  123. dinic();
  124. dfs1(s,xx);
  125. }
  126. int T;
  127. int main()
  128. {
  129. scanf("%d",&T);
  130. while (T--)
  131. {
  132. memset(num,-1,sizeof(num));
  133. memset(ans,0,sizeof(ans));
  134. init();
  135. n=read(),m=read();
  136. for (int i=1;i<=m;i++) x[i]=read(),y[i]=read();
  137. int k;
  138. k=read();
  139. for (int i=1;i<=k;i++)
  140. {
  141. int oo;
  142. oo=read();
  143. num[oo]=read();
  144. }
  145. for (int i=0;i<=32;i++)
  146. {
  147. build(i);
  148. }
  149. for (int i=1;i<=n;i++) printf("%d\n",ans[i]);
  150. }
  151. return 0;
  152. }

spoj839 Optimal Marks(最小割,dinic)的更多相关文章

  1. 【BZOJ2400】Spoj 839 Optimal Marks 最小割

    [BZOJ2400]Spoj 839 Optimal Marks Description 定义无向图中的一条边的值为:这条边连接的两个点的值的异或值. 定义一个无向图的值为:这个无向图所有边的值的和. ...

  2. [SPOJ839]Optimal Marks

    [SPOJ839]Optimal Marks 试题描述 You are given an undirected graph \(G(V, E)\). Each vertex has a mark wh ...

  3. SPOJ839 Optimal Marks(最小割)

    题目大概说给一张图,每个点都有权,边的权等于其两端点权的异或和,现已知几个点的权,为了使所有边的边权和最小,其他点的权值该是多少. 很有意思的一道题,完全看不出和网络流有什么关系. 考虑每个未知的点$ ...

  4. 【BZOJ-2400】Spoj839Optimal Marks 最小割 + DFS

    2400: Spoj 839 Optimal Marks Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 567  Solved: 202[Submit ...

  5. bzoj 3144 [Hnoi2013]切糕【最小割+dinic】

    都说了是'切'糕所以是最小割咯 建图: 每个点向下一层连容量为这个点的val的边,S向第一层连容量为inf的边,最后一层向T连容量为自身val的边,即割断这条边相当于\( f(i,j) \)选择了当前 ...

  6. bzoj 2127 happiness【最小割+dinic】

    参考:https://www.cnblogs.com/chenyushuo/p/5144957.html 不得不说这个建图方法真是非常妙啊 假设S点选理,T点选文,a[i][j]为(i,j)选文收益, ...

  7. bzoj 2132 圈地计划【最小割+dinic】

    对于网格图,尤其是这种要求相邻各自不同的,考虑黑白染色 对于这张染色后图来说: 对于每个黑格: 表示初始时选择商业区: s点向它连商业区收益的流量,它向t点连工业区收益的流量: 割断S侧的边说明反悔, ...

  8. bzoj 3894 文理分科【最小割+dinic】

    谁说这道和2127是双倍经验的来着完全不一样啊? 数组开小会TLE!数组开小会TLE!数组开小会TLE! 首先sum统计所有收益 对于当前点\( (i,j) \)考虑,设\( x=(i-1)*m+j ...

  9. [2019杭电多校第一场][hdu6582]Path(最短路&&最小割)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 题意:删掉边使得1到n的最短路改变,删掉边的代价为该边的边权.求最小代价. 比赛时一片浆糊,赛后 ...

随机推荐

  1. Hexo搭建个人静态博客网站

    前言 前段时间博客园整改,许多博客无法查看,偶然的机会接触到了许多博客框架,可用来快速搭建一个静态博客网站:最后选择使用hexo,看了不少大佬的教程,觉得挺有意思的,于是也总结了一下自己的搭建步骤,可 ...

  2. Promise.all()

    语法:Promise.all(iterable); 参数:iterable 一个可迭代对象,如 Array 或 String. 返回值:如果传入的参数是一个空的可迭代对象,则返回一个已完成(alrea ...

  3. freeswitch的event事件处理

    概述 之前的文章中,我们讲解了freeswitch的源码基本结构,如何新增一个插件式模块,以及如何在模块中新增一个命令式API接口和APP接口. freeswitch本身是事件驱动的,它可以并发响应多 ...

  4. 一文读懂Base64编码

    Base64编码 字符对应表 上表就是用来表示Base64,一共64个字符,A-Z,a-z,0-9,+,-,还有=(作为补位) 无论将文件,字符串,还是什么转为Base64,一定是用上表的字符表示. ...

  5. ubuntu 20.04 发邮件配置

    安装sendmail后,发邮件一直没有成功,因此卸载sendmail后,安装heirloom-mailx. # unbuntu 18.04和20.04移除了heirloom-mailx,需要另外配置软 ...

  6. TreeListLookUpEdit控件使用

    绑定数据 treeListLookUpEdit1.Properties.DataSource=list;增加列treeListLookUpEdit1.Properties.TreeList.Colum ...

  7. 解析Prometheus PromQL

    解析PromQL 目前对Prometheus 的promQL 的解析文章比较少,且Prometheus官方也没有提供一个公共的库来对齐进行解析.下面实现对promQL的解析,并实现注入label功能. ...

  8. [Python]爬虫获取知乎某个问题下所有图片并去除水印

    获取URL 进入某个知乎问题的主页下,按F12打开开发者工具后查看network面板. network面板可以查看页面向服务器请求的资源.资源的大小.加载资源花费的时间以及哪些资源加载失败等信息.还可 ...

  9. Django学习day09随堂笔记

    每日测验 """ 今日考题: 1.choices参数的应用场景有哪些,如何获取该字段的值 2.django是什么模型的框架,简述MTV与MVC模型 3.多对多表关系有几种 ...

  10. nginx环境下提交表单一直301

    之前网站一直正常的,现在提交表单一直301 原因: 前几天把网站http升为https协议,需要去掉连接 // 前内容 把 <form method ="post" acti ...