我真是一只菜狗。。。。。。emm。。。

题意:

  判断一个从1开始的队列是否可以按照bfs的顺序 进行遍历。。必须从1开始。。。然后后边依次是bfs顺序

解析:

  看代码能看懂吧。。。emm。。。就是把每个有关系的用map标记一下

  然后bfs的时候 加一个循环进队列就好了  emm。。/。

  

  1. #include <bits/stdc++.h>
  2. #define rap(i, a, n) for(int i=a; i<=n; i++)
  3. #define rep(i, a, n) for(int i=a; i<n; i++)
  4. #define lap(i, a, n) for(int i=n; i>=a; i--)
  5. #define lep(i, a, n) for(int i=n; i>a; i--)
  6. #define rd(a) scanf("%d", &a)
  7. #define rlld(a) scanf("%lld", &a)
  8. #define rc(a) scanf("%c", &a)
  9. #define rs(a) scanf("%s", a)
  10. #define pd(a) printf("%d\n", a);
  11. #define plld(a) printf("%lld\n", a);
  12. #define pc(a) printf("%c\n", a);
  13. #define ps(a) printf("%s\n", a);
  14. #define MOD 2018
  15. #define LL long long
  16. #define ULL unsigned long long
  17. using namespace std;
  18. const int maxn = , INF = 0x7fffffff;
  19. int n;
  20. map<int, bool> w[maxn];
  21. int a[maxn];
  22. bool bfs()
  23. {
  24. queue<int> Q;
  25. int nex = ;
  26. if(a[nex] != ) return false;
  27. Q.push(a[nex]);
  28. nex++;
  29. while(!Q.empty())
  30. {
  31. int u = Q.front(); Q.pop();
  32. int v = a[nex];
  33. while(w[u][v])
  34. {
  35. Q.push(v);
  36. nex++;
  37. v = a[nex];
  38. }
  39. }
  40. if(nex == n) return true;
  41. return false;
  42. }
  43.  
  44. int main()
  45. {
  46. rd(n);
  47. int u, v;
  48. rep(i, , n-)
  49. {
  50. rd(u), rd(v);
  51. w[u][v] = w[v][u] = ;
  52. }
  53. rep(i, , n)
  54. rd(a[i]);
  55. if(n == ) cout<< "Yes" <<endl;
  56. else if(bfs()) cout<< "Yes" <<endl;
  57. else cout<< "No" <<endl;
  58.  
  59. return ;
  60. }

Valid BFS? CodeForces - 1037D(思维 bfs)的更多相关文章

  1. Codeforces 1037D【BFS】

    <题目链接> 题目大意: 给你一颗树的所有边,这些边是无向的,然后给你一段BFS序列,BFS都以1为根节点,判断这段BFS序列是否合法. 解题分析: 就是模拟BFS,某个父亲节点的所有子节 ...

  2. CodeForces 586D【BFS】

    题意: s是这个人开始位置:连续相同大写字母是 Each of the k trains,相应的火车具有相应的字母: '.' 代表空: 有个人在最左列,上面有连续字母代表的火车,火车从左边出去的话,会 ...

  3. POJ 1915-Knight Moves (单向BFS &amp;&amp; 双向BFS 比)

    主题链接:Knight Moves 题意:8个方向的 马跳式走法 ,已知起点 和终点,求最短路 研究了一下双向BFS,不是非常难,和普通的BFS一样.双向BFS只是是从 起点和终点同一时候開始搜索,可 ...

  4. [codeforces 1037D] Valid BFS? 解题报告(验证bfs序,思维题)

    题目链接:http://codeforces.com/problemset/problem/1037/D 题目大意: 给出一棵树,询问一个序列是否可能为这棵树从节点1开始遍历的bfs序 题解: 对于每 ...

  5. [Codeforces 1037D] Valid BFS?

    [题目链接] http://codeforces.com/problemset/problem/1037/D [算法] 首先求出每个点的父节点 , 每棵子树的大小 然后判断BFS序是否合法即可 时间复 ...

  6. 【Codeforces 1037D】Valid BFS?

    [链接] 我是链接,点我呀:) [题意] 让你判断一个序列是否可能为一个bfs的序列 [题解] 先dfs出来每一层有多少个点,以及每个点是属于哪一层的. 每一层的bfs如果有先后顺序的话,下一层的节点 ...

  7. Codeforces Round #297 (Div. 2) D. Arthur and Walls [ 思维 + bfs ]

    传送门 D. Arthur and Walls time limit per test 2 seconds memory limit per test 512 megabytes input stan ...

  8. Vladik and Favorite Game CodeForces - 811D (思维+BFS+模拟+交互题)

    D. Vladik and Favorite Game time limit per test 2 seconds memory limit per test 256 megabytes input ...

  9. CodeForces - 377A Maze BFS逆思维

    Maze Pavel loves grid mazes. A grid maze is an n × m rectangle maze where each cell is either empty, ...

随机推荐

  1. EF Core中如何取消跟踪DbContext中所有被跟踪的实体

    首先定义一个DbContext的扩展类DbContextDetachAllExtension,其中包含一个DbContext的扩展方法DetachAll,用来取消跟踪DbContext中所有被跟踪的实 ...

  2. R 语言的Dataframe常用操作

    上节我们简单介绍了Dataframe的定义,这节我们具体来看一下Dataframe的操作 首先,数据框的创建函数为 data.frame( ),参考R语言的帮助文档,我们来了解一下data.frame ...

  3. boot.img的修改

    个文件:boot.img.system.img.userdata.img.其中boot.img 存放着内核以及Android系统的配置信息,比如android系统各文件夹的读写权限,adb 的权限.所 ...

  4. 20155223 Exp7 网络欺诈防范

    20155223 Exp7 网络欺诈防范 基础问题回答 通常在什么场景下容易受到DNS spoof攻击? 无设防或防护力特别弟弟低的公共局域网,或者是在同一个局域网下. 在日常生活工作中如何防范以上两 ...

  5. [Oracle]System 表空间的文件丢失

    如果system 表空间的文件丢失,假设有备份的情况,可以恢复.数据库需要设置为mount 状态,然后restore/recover datafile 模拟实验: SQL> select nam ...

  6. MiZ702学习笔记11——如何使用vivado isim仿真

    说到vivado的仿真确实是很有意思,不管是ISE还是Quartus都可以自己自动生成测试平台的完整构架,但是vivado不行,所有的测试代码自己写!(我反正是查了好久,都没发现vivado如何自动生 ...

  7. 微信小程序 Echarts 异步数据更新

    微信小程序 Echarts 异步数据更新的练习,被坑了很多次,特作记录. 作者:罗兵 地址:https://www.cnblogs.com/hhh5460/p/9989805.html 0.效果图   ...

  8. 开源软件License汇总

    用到的open source code越多,遇到的开源License协议就越多.License是软件的授权许可,里面详尽表述了你获得代码后拥有的权利,可以对别人的作品进行何种操作,何种操作又是被禁止的 ...

  9. Linux 学习日记 2 (常用命令 + deb包的安装)

    常用命令:以下是一些比较常用的命令,主要是关于安装软件的一些命令 @_@ cd ~/下载(文件名)/ //进入这个文件夹 , ~指的是根目录 cd .. //返回上一级文件夹 sudo apt-get ...

  10. 起步 - vue-router路由与页面间导航

    vue-router 我们知道路由定义了一系列访问的地址规则,路由引擎根据这些规则匹配找到对应的处理页面,然后将请求转发给页进行处理.可以说所有的后端开发都是这样做的,而前端路由是不存在"请 ...