[HNOI2019]校园旅行(bfs)

题面

洛谷

题解

首先考虑暴力做法怎么做。

把所有可行的二元组全部丢进队列里,每次两个点分别向两侧拓展一个同色点,然后更新可行的情况。

这样子的复杂度是\(O(m^2)\)的。

考虑如何优化边数,先说结论:

首先对于一个同色联通块,如果它是一个二分图,那么只需要保留一棵生成树就行了,否则随便找个点连一条自环。

对于连接不同色两个点的边,一定构成一个二分图,只需要保留一棵生成树就行了。

证明是这样子的:

首先我们把路径划分成若干个同色连续段,那么我们要做的就是对应的两段长度要相等。

长度短了是无所谓的,我们可以反复走一条边,达到把序列边长的目的。

对于一个二分图而言,如果反复走,其长度的奇偶性不会改变,否则奇偶性可以任意改变,那么需要连一个自环来改变奇偶性。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cstdlib>
  4. #include<cstring>
  5. #include<cmath>
  6. #include<algorithm>
  7. #include<vector>
  8. #include<queue>
  9. using namespace std;
  10. #define ll long long
  11. #define MAX 5050
  12. inline int read()
  13. {
  14. int x=0;char ch=getchar();bool fl=false;
  15. while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
  16. if(ch=='-')fl=true,ch=getchar();
  17. while(ch>='0'&&ch<='9')x=x*10+ch-48,ch=getchar();
  18. return fl?-x:x;
  19. }
  20. struct Line{int v,next;}e[500500<<1];
  21. int h[MAX],cnt=1;
  22. inline void Add(int u,int v){e[cnt]=(Line){v,h[u]};h[u]=cnt++;}
  23. int n,m,Qr;char a[MAX];
  24. struct Node{int x,y;};queue<Node> Q;
  25. bool vis[MAX][MAX];
  26. vector<int> E[MAX];
  27. int col[MAX];bool chk;
  28. int f[MAX];
  29. int getf(int x){return x==f[x]?x:f[x]=getf(f[x]);}
  30. void dfs(int u,int c)
  31. {
  32. col[u]=c;
  33. for(int i=0,l=E[u].size();i<l;++i)
  34. {
  35. int v=E[u][i];
  36. if(a[u]!=a[v])continue;
  37. if(col[v]==col[u])chk=false;
  38. if(col[v])continue;
  39. Add(u,v),Add(v,u);dfs(v,c^1);
  40. vis[u][v]=vis[v][u]=true;
  41. Q.push((Node){u,v});
  42. }
  43. }
  44. int main()
  45. {
  46. freopen("tour.in","r",stdin);
  47. freopen("tour.out","w",stdout);
  48. n=read();m=read();Qr=read();scanf("%s",a+1);
  49. for(int i=1;i<=n;++i)f[i]=i;
  50. for(int i=1;i<=m;++i)
  51. {
  52. int u=read(),v=read();
  53. E[u].push_back(v);
  54. E[v].push_back(u);
  55. if(a[u]!=a[v])
  56. {
  57. if(getf(u)==getf(v))continue;
  58. Add(u,v);Add(v,u);
  59. f[getf(u)]=getf(v);
  60. }
  61. }
  62. for(int i=1;i<=n;++i)
  63. if(!col[i])
  64. {
  65. chk=true;dfs(i,2);
  66. if(!chk)Add(i,i);
  67. }
  68. for(int i=1;i<=n;++i)vis[i][i]=true,Q.push((Node){i,i});
  69. while(!Q.empty())
  70. {
  71. Node u=Q.front();Q.pop();
  72. int x=u.x,y=u.y;
  73. for(int i=h[x];i;i=e[i].next)
  74. {
  75. int xx=e[i].v;
  76. for(int j=h[y];j;j=e[j].next)
  77. {
  78. int yy=e[j].v;
  79. if(vis[xx][yy])continue;
  80. if(a[xx]!=a[yy])continue;
  81. vis[xx][yy]=vis[yy][xx]=true;
  82. Q.push((Node){xx,yy});
  83. }
  84. }
  85. }
  86. while(Qr--)
  87. {
  88. int x=read(),y=read();
  89. if(vis[x][y])puts("YES");
  90. else puts("NO");
  91. }
  92. return 0;
  93. }

【BZOJ5492】[HNOI2019]校园旅行(bfs)的更多相关文章

  1. bzoj5492:[Hnoi2019]校园旅行

    传送门 %%%myy 考虑30分做法:暴力bfs,\(f[i][j]\)表示\(i\)到\(j\)可以形成回文串 然而为什么我场上只想到了70分做法,完全没想到30分怎么写.. 100分: 考虑缩边, ...

  2. [HNOI2019]校园旅行(构造+生成树+动规)

    题目 [HNOI2019]校园旅行 做法 最朴素的做法就是点对扩展\(O(m^2)\) 发现\(n\)比较小,我们是否能从\(n\)下手减少边数呢?是肯定的 单独看一个颜色的联通块,如果是二分图,我们 ...

  3. LOJ 3057 「HNOI2019」校园旅行——BFS+图等价转化

    题目:https://loj.ac/problem/3057 想令 b[ i ][ j ] 表示两点是否可行,从可行的点对扩展.但不知道顺序,所以写了卡时间做数次 m2 迭代的算法,就是每次遍历所有不 ...

  4. [HNOI2019]校园旅行(建图优化+bfs)

    30分的O(m^2)做法应该比较容易想到:令f[i][j]表示i->j是否有解,然后把每个路径点数不超过2的有解状态(u,v)加入队列,然后弹出队列时,两点分别向两边搜索边,发现颜色一样时,再修 ...

  5. 【洛谷5292】[HNOI2019] 校园旅行(思维DP)

    点此看题面 大致题意: 给你一张无向图,每个点权值为\(0\)或\(1\),多组询问两点之间是否存在一条回文路径. 暴力\(DP\) 首先,看到\(n\)如此之小(\(n\le5000\)),便容易想 ...

  6. Luogu P5292 [HNOI2019]校园旅行

    非常妙的一道思博题啊,不愧是myy出的题 首先我们考虑一个暴力DP,直接开一个数组\(f_{i,j}\)表示\(i\to j\)的路径能否构成回文串 考虑直接拿一个队列来转移,队列里存的都是\(f_{ ...

  7. [HNOI2019]校园旅行

    题意 https://www.luogu.org/problemnew/show/P5292 思考 最朴素的想法,从可行的二元组(u,v)向外拓展,及u的出边所指的颜色与v的出边所指的颜色若相同,继续 ...

  8. 洛谷P5292 [HNOI2019]校园旅行(二分图+最短路)

    题面 传送门 题解 如果暴力的话,我们可以把所有的二元组全都扔进一个队列里,然后每次往两边更新同色点,这样的话复杂度是\(O(m^2)\) 怎么优化呢? 对于一个同色联通块,如果它是一个二分图,我们只 ...

  9. [LOJ3057] [HNOI2019] 校园旅行

    题目链接 LOJ:https://loj.ac/problem/3057 洛谷:https://www.luogu.org/problemnew/show/P5292 Solution 先膜一发\(m ...

随机推荐

  1. iOS----------developerDiskImage

    真机测试时提示Could not find Developer Disk Image.这该怎么办???? 这是由于真机系统过高或者过低,Xcode中没有匹配的配置包文件,我们可以通过这个路径进入配置包 ...

  2. 接入渠道SDK时出现乙方SDK回调不起作用

    使用activity.runOnUiThread(new Runnable() {}  方法去解决

  3. 测者的测试技术手册:自动的自动化框架EvoSuite集成Cobertura得到可视化的代码覆盖报告

    EvoSuite是由Sheffield等大学联合开发的一种开源工具,用于自动生成测试用例集,生成的测试用例均符合Junit的标准,可直接在Junit中运行.得到了Google和Yourkit的支持. ...

  4. macos 安装sublime text 3,如何安装插件

    1. 上面的代码如下: import urllib.request,os,hashlib; h = '2915d1851351e5ee549c20394736b442' + '8bc59f460fa1 ...

  5. Python之--paramiko实例

    一.基于SFTPClient类连接sshd服务器: 特点: 一般用于实现对远程服务器的上传, 下载和对远程目录文件的操作 import pramiko hostname = '172.24.0.110 ...

  6. MongoDB 常用的数据备份梳理汇总

    1.基于数据文件的备份 直接将原始的数据文件Copy至备份的地方,这个方法的优点是比较快,因为备份和恢复都不需要转换数据格式.缺点就是需要锁住数据库服务器,但是此方案通常备份是在从节点上进行,备份过程 ...

  7. [20190401]隐含参数_mutex_spin_count.txt

    [20190401]隐含参数_mutex_spin_count.txt --//上午做了一些测试关于semtimedop函数调用,发现自己上个星期在一些问题上理解错误.--//相关链接:--//htt ...

  8. Linux之Samba部署

    1.Samba介绍 Samba 是在 Linux 和 UNIX 系统上实现 SMB 协议的一个免费软件,由服务器及客户端程序构成,SMB(Server Messages Block,信息服务块)是一种 ...

  9. 关于使用国内dock仓库,网易、DaoCloud

    使用国内docker镜像仓库,大大提高镜像的下载速度,从docker hub下载慢的不要不要的,甚至根本下载不了镜像,在docker for windows 18.06中增加一个配置即可,非常简单,具 ...

  10. 秒杀系统HTML倒计时设置

    倒计时就是在秒杀表中设定好要秒杀的时间 再减去现在的时间 把时间差显示在页面上 由于第一次搞秒杀倒计时  辛苦搞了半天  留此微博  以留备用 <!DOCTYPE html PUBLIC &qu ...