cf813C(bfs)
题目链接:http://codeforces.com/problemset/problem/813/C
题意:给出一颗树,开始时两个人 Alice 和 Bob 分别站在 1(树根)和 x 处.此后每一次操作两人都可以选择在原地不动或者移动到相邻的节点(Bob先移动);
直至两人移到同一个位置,两人移动的总步数为 ans,Alice要使 ans 尽量小,Bob 要使 ans 尽量大,输出ans;
思路:假设最终在 p 位置相遇,显然 p 是由先移动的 Bob 决定的,即 p 能使 ans 最大;
用 dis1[p] 表示 1 到 p 的距离,dis2[p] 表示 x 到 p 的距离,要满足 Alice 和 Bob 在移动到 p 之前不相遇,所以有 dis1[p] > dis2[p],那么显然有 ans = 2 * dis1[p];
即:先 bfs 出 1 和 x 到其他节点的最短距离,再遍历所有节点,对于节点 i,若满足 dis1[i] > dis2[i] ,则 ans = max(ans, 2 * dis1[i]),最终输出 ans 即可;
代码:
#include <iostream>
#include <stdio.h>
#include <vector>
#include <queue>
#include <string.h>
using namespace std; const int MAXN = 2e5 + ;
vector<int> mp[MAXN];
bool vis[MAXN]; void bfs(int dis[MAXN], int p){//求以 p 为根时其余个点到 p 的距离
memset(vis, , sizeof(vis));
int ans = , cnt1 = , cnt2 = ;
queue<int> q;
q.push(p);
vis[p] = true;
while(!q.empty()){
while(cnt1--){
int cnt = q.front();
q.pop();
for(int i = ; i < mp[cnt].size(); i++){
int cc = mp[cnt][i];
if(!vis[cc]){
q.push(mp[cnt][i]);
vis[mp[cnt][i]] = true;
cnt2++;
}
}
dis[cnt] = ans;
}
cnt1 = cnt2;
cnt2 = ;
ans++;
}
} int main(void){
int n, x;
scanf("%d%d", &n, &x);
for(int i = ; i < n - ; i++){
int s, e;
scanf("%d%d", &s, &e);
mp[s].push_back(e);
mp[e].push_back(s);
}
int dis1[MAXN], dis2[MAXN];
bfs(dis1, );
bfs(dis2, x);
int ans = ;
for(int i = ; i <= n; i++){
if(dis1[i] > dis2[i] && mp[i].size() == ){
ans = max(ans, dis1[i]*);
}
}
cout << ans << endl;
return ;
}
cf813C(bfs)的更多相关文章
- 图的遍历(搜索)算法(深度优先算法DFS和广度优先算法BFS)
		
图的遍历的定义: 从图的某个顶点出发访问遍图中所有顶点,且每个顶点仅被访问一次.(连通图与非连通图) 深度优先遍历(DFS): 1.访问指定的起始顶点: 2.若当前访问的顶点的邻接顶点有未被访问的,则 ...
 - 【BZOJ-1656】The Grove  树木       BFS + 射线法
		
1656: [Usaco2006 Jan] The Grove 树木 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 186 Solved: 118[Su ...
 - POJ 3278 Catch That Cow(bfs)
		
传送门 Catch That Cow Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 80273 Accepted: 25 ...
 - POJ 2251 Dungeon Master(3D迷宫 bfs)
		
传送门 Dungeon Master Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 28416 Accepted: 11 ...
 - Sicily 1215: 脱离地牢(BFS)
		
这道题按照题意直接BFS即可,主要要注意题意中的相遇是指两种情况:一种是同时到达同一格子,另一种是在移动时相遇,如Paris在(1,2),而Helen在(1,2),若下一步Paris到达(1,1),而 ...
 - Sicily 1048: Inverso(BFS)
		
题意是给出一个3*3的黑白网格,每点击其中一格就会使某些格子的颜色发生转变,求达到目标状态网格的操作.可用BFS搜索解答,用vector储存每次的操作 #include<bits/stdc++. ...
 - Sicily 1444: Prime Path(BFS)
		
题意为给出两个四位素数A.B,每次只能对A的某一位数字进行修改,使它成为另一个四位的素数,问最少经过多少操作,能使A变到B.可以直接进行BFS搜索 #include<bits/stdc++.h& ...
 - Sicily 1051: 魔板(BFS+排重)
		
相对1150题来说,这道题的N可能超过10,所以需要进行排重,即相同状态的魔板不要重复压倒队列里,这里我用map储存操作过的状态,也可以用康托编码来储存状态,这样时间缩短为0.03秒.关于康托展开可以 ...
 - Sicily 1150: 简单魔板(BFS)
		
此题可以使用BFS进行解答,使用8位的十进制数来储存魔板的状态,用BFS进行搜索即可 #include <bits/stdc++.h> using namespace std; int o ...
 
随机推荐
- terminal中  启动ios模拟器,并安装软件
			
启动运行模拟器: xcrun instruments -w 'iPhone 6 Plus' 在已经启动好的模拟器中安装应用: xcrun simctl install booted Calculato ...
 - Java for LeetCode 080 Remove Duplicates from Sorted Array II
			
Follow up for "Remove Duplicates": What if duplicates are allowed at most twice? For examp ...
 - [2018-11-03]2018年10月28日宁波dotnet社区活动回顾及下次活动预告
			
离上次活动,有半年了,汗.之后尽量保证每月一次,以组织为主,多邀请嘉宾来分享. 本次活动不足之处 人手不足:由于活动组织事项受限于人手(目前就我一个,这次活动前后我又应邀给大红鹰学院应届生介绍dotn ...
 - 算法(Algorithms)第4版 练习 1.3.9
			
主要思路: 用Dijkstra的双栈算法. 遇到数字则压入数字栈中(String). 遇到运算符则压入运算符栈中(String). 遇到右括号时,从数字栈和运算法栈中弹出相应的元素,生成相应的运算表达 ...
 - jumpserver v3.0
			
文档地址 www.php230.com/weixin1451347094.html
 - Java并发知识概述
			
1.Java内存模型的抽象结构 Java中,所有的实例.静态域和数组元素都存储在堆内存中,堆内存是线程共享的.局部变量,形参,异常处理参数不会在线程之间共享,所以不存在内存可见性问题,也就不受内存模型 ...
 - mac下配置java运行环境
			
1. oracle官网下载java se jdk地址 http://www.oracle.com/technetwork/java/javase/downloads/jdk9-downloads-38 ...
 - Gym:101630J - Journey from Petersburg to Moscow(最短路)
			
题意:求1到N的最短路,最短路的定义为路径上最大的K条边. 思路:对于每种边权,假设为X,它是第K大,那么小于X的变为0,大于K的,边权-X.然后求最短路,用dis[N]+K*X更新答案. 而小于K的 ...
 - tcp攻击
 - <十七>UML核心视图动态视图之时序图
			
一:时序图 --->时序图是用于描述按时间顺序排列的对象之间的交互模式. --->它按照参与交互的对象所具有的“生命线”和他们相互发送的消息来显示这些对象. --->时序图包含对象和 ...