UVA - 208 Firetruck(并查集+dfs)
题目:
给出一个结点d和一个无向图中所有的边,按字典序输出这个无向图中所有从1到d的路径。
思路:
1.看到紫书上的提示,如果不预先判断结点1是否能直接到达结点d,上来就直接dfs搜索的话会超时,于是就想到了用并查集来预先判断是否属于同一个连通分量。
2.可以将与d属于同一个连通分量的点用一个数组保存起来,然后dfs搜索这个数组就可以了,这也就是只搜索了与d在一个连通分量里的点。
3.当搜索到d的时候就输出路径。
代码:
#include <bits/stdc++.h>
#define inf 0x3f3f3f3f
#define MAX 1e3
#define FRE() freopen("in.txt","r",stdin)
#define FRO() freopen("out.txt","w",stdout)
using namespace std;
typedef long long ll;
const int maxn = ;
bool mp[maxn][maxn];
int fa[maxn],d,lk[maxn],vis[maxn];
int idx,path[maxn],cnt; void init(){
for(int i=; i<maxn; i++){
fa[i] = i;
}
memset(lk,,sizeof(lk));
memset(vis,,sizeof(vis));
memset(mp,,sizeof(mp));
memset(path,,sizeof(path));
} int _find(int x){//并查集查找祖先
return fa[x]==x ? x : fa[x] = _find(fa[x]);
} void mergeNode(int x,int y){//合并不属于同一个连通分量的两个点
int tx = _find(x),ty = _find(y);
if(tx != ty){
fa[tx] = ty;
}
} bool isLinked(int x,int y){//判断两个点是不是属于同一个连通分量
if(_find(x)!=_find(y)){
return false;
}
return true;
} void DFS(int now, int MX){
if(now==d){//搜索到d就输出;路径
cnt++;
printf("");
for(int i=; i<MX; i++){
printf(" %d",path[i]);
}
printf("\n");
}else{
//cout<<now<<endl;
for(int i=; i<idx; i++){
int u = lk[i];
if(!vis[u] && mp[now][u]){
vis[u] = true;
path[MX] = u;//这里其实没必要另开一个数组保存路径,在下一个循环的时候当前的路径已经输出或没用了
DFS(u,MX+);
vis[u] = false;
}
}
}
} void check(){
for(int i=; i<idx; i++){
printf("%d ",lk[i]);
}
printf("\n");
} int main(){
//FRE();
int kase=;
while(scanf("%d",&d)!=EOF){
int st,en;
init();
while(scanf("%d%d",&st,&en)&&st){
mp[st][en] = ;
mp[en][st] = ;
mergeNode(st,en);
}
printf("CASE %d:\n",++kase);
if(isLinked(,d)==false){
printf("There are 0 routes from the firestation to streetcorner %d.\n",d);
}else{
idx=;
for(int i=; i<maxn; i++){//找到与d在同一个连通分量里边的点并保存
if(isLinked(i, d)){
lk[idx++] = i;
}
}
sort(lk,lk+idx);//从小到大排序,保证字典序
//check();
cnt = ;
DFS(, );
printf("There are %d routes from the firestation to streetcorner %d.\n",cnt,d);
}
}
return ;
}
UVA - 208 Firetruck(并查集+dfs)的更多相关文章
- UVA - 208 Firetruck(消防车)(并查集+回溯)
题意:输入着火点n,求结点1到结点n的所有路径,按字典序输出,要求结点不能重复经过. 分析:用并查集事先判断结点1是否可以到达结点k,否则会超时.dfs即可. #pragma comment(link ...
- HDU 1232 并查集/dfs
原题: http://acm.hdu.edu.cn/showproblem.php?pid=1232 我的第一道并查集题目,刚刚学会,我是照着<啊哈算法>这本书学会的,感觉非常通俗易懂,另 ...
- 1021.Deepest Root (并查集+DFS树的深度)
A graph which is connected and acyclic can be considered a tree. The height of the tree depends on t ...
- POJ1291-并查集/dfs
并查集 题意:找出给定的这些话中是否有冲突.若没有则最多有多少句是对的. /* 思路:如果第x句说y是对的,则x,y必定是一起的,x+n,y+n是一起的:反之x,y+n//y,x+n是一起的. 利用并 ...
- UVa 208 - Firetruck 回溯+剪枝 数据
题意:构造出一张图,给出一个点,字典序输出所有从1到该点的路径. 裸搜会超时的题目,其实题目的数据特地设计得让图稠密但起点和终点却不相连,所以直接搜索过去会超时. 只要判断下起点和终点能不能相连就行了 ...
- F2 - Spanning Tree with One Fixed Degree - 并查集+DFS
这道题还是非常有意思的,题意很简单,就是给定一个图,和图上的双向边,要求1号节点的度(连接边的条数)等于K,求这棵树的生成树. 我们首先要解决,如何让1号节点的度时为k的呢???而且求的是生成树,意思 ...
- UVA208-Firetruck(并查集+dfs)
Problem UVA208-Firetruck Accept:1733 Submit:14538 Time Limit: 3000 mSec Problem Description The Ce ...
- 2018 计蒜之道复赛 贝壳找房魔法师顾问(并查集+dfs判环)
贝壳找房在遥远的传奇境外,找到了一个强大的魔法师顾问.他有 22 串数量相同的法力水晶,每个法力水晶可能有不同的颜色.为了方便起见,可以将每串法力水晶视为一个长度不大于 10^5105,字符集不大于 ...
- Codeforces 455C Civilization(并查集+dfs)
题目链接:Codeforces 455C Civilization 题目大意:给定N.M和Q,N表示有N个城市,M条已经修好的路,修好的路是不能改变的.然后是Q次操作.操作分为两种.一种是查询城市x所 ...
随机推荐
- Delphi中WebBrowser控件打开部分网站报"Invalid floating point operation”解决
Delphi中WebBrowser控件打开部分网站报"Invalid floating point operation”解决 EmbeddedWBWebBrowserDelphi 最近用E ...
- Email-ext plugin
https://wiki.jenkins.io/display/JENKINS/Email-ext+plugin General This plugin extends Jenkins built i ...
- ubuntu下的root的创建进入与退出
创建: 在终端中输入:sudo passwd rootEnter new UNIX password: (在这输入你的密码)Retype new UNIX password: (确定你输入的密码)pa ...
- java异常——重新抛出异常
有时候希望把刚捕获的异常重新抛出,尤其是在使用Exception捕获所有异常的时候.既然已经得到了对当前异常对象的引用,可以直接把它重新抛出: catch(Exception e){ System.o ...
- Mac系统打开命令行终端及查看操作系统版本号的方法
Mac系统打开命令行终端的方法: 应用程序 --> 实用工具 --> 终端 Mac系统终端查看操作系统版本号的方法: 输入:#more /System/Library/CoreServic ...
- mac系统下的常用命令
这是我日常在mac下记录的一些常用终端命令: 1 java 2 javac 3 exit 4 /Users/lianxumac/Desktop/apktool1.5.2/反编译 ; exit; 5 / ...
- poj2154 Color ——Polya定理
题目:http://poj.org/problem?id=2154 今天学了个高端的东西,Polya定理... 此题就是模板,然而还是写了好久好久... 具体看这个博客吧:https://blog.c ...
- Angular学习日记(一) 开发环境的搭建
从看视频到自己尝试,总会走很多的弯路才能成功. 首先:装最新版的nodejs. 第一种:使用npm安装 首先设置taobao镜像,npm config set registry https://reg ...
- openstack dnsmasq彭祖
Openstack dnsmasq配置域名解析,openstackdnsmasq vi /etc/nova/nova.conf 在[DEFAULT]添加 dnsmasq_config_file=/et ...
- 源码阅读之ArrayList(JDK8)
ArrayList概述 ArrayList是一个的可变数组的实现,实现了所有可选列表操作,并允许包括 null 在内的所有元素.每个ArrayList实例都有一个容量,该容量是指用来存储列表元素的数组 ...