【问题描述】

某旅游公司组团去迪拜世界岛旅游。世界岛由n个岛屿组成,岛屿序号为1~n,这些岛屿都直接或间接相连。岛屿之间用桥梁连接。现从1号岛屿开始游览,并约定按如下方式游览:

1) 每游览完一个岛屿,接下来游览与该岛屿有桥梁直接连接的、未游览过的岛屿。如果存在多个邻接的岛屿,则优先选择序号最小的岛屿。如果该岛屿没有未游览过的相邻岛屿,则返回到该岛屿的上一个岛屿。

2) 每个岛屿都不会重复游览。

另外,对每个岛屿,定义两个时间:

1) 到达该岛屿的时间dfn1;

2) 离开该岛屿的时间dfn2;

时间从1开始计起,游览岛屿的时间不计,每到达一个岛屿,时间加1。如果到达某岛屿后由于没有未游览过的相邻岛屿而随即马上离开,则离开时时间也要加1,详见测试数据。

【输入形式】

输入文件中包含多个测试数据。每个测试数据的第一行为两个正整数n和m,2≤n≤20,分别表示岛屿数和桥梁数;接下来有m行,每行描述了一座桥梁,用该桥梁连接的两个岛屿序号表示;没有连接某个岛屿自身的桥梁,且任何两个岛屿之间最多有一座桥。输入文件最后一行为0 0,表示输入结束。

【输出形式】

对输入文件中的每个测试数据,输出两行,第1行为n个整数,用空格隔开,为第1~n个顶点的时间dfn1;第1行为n个整数,用空格隔开,为第1~n个顶点的时间dfn2。

【样例输入】

7 8
1 4
1 6
1 7
2 3
2 7
3 5
3 6
5 6
0 0

【样例输出】

1 6 5 2 10 4 714 9 12 3 11 13 8


【分析】

题目不是很难,主要是把节点信息读入,然后利用dfs,关键是在过程中需要理清各节点d1和d2的关系。

【代码】

#include <stdio.h>
#include <iostream>
using namespace std;
struct land {
int d1;//登岛时间
int d2;//离岛时间
};
bool maze[][];
bool vist[];
land a[];//记录实践
int n, m;//岛数 桥数
int length;
int dfs(int c) {
a[c].d2 = a[c].d1;
int i = ;
int t = ;
for (i = ; i <= n&&length; i++) {
if (vist[i] == && maze[c][i] == ) {
vist[i] = ;
length--;//未访问的岛数量减一
a[i].d1 = a[c].d2 + ;
a[c].d2 = dfs(i);
t = i;//记录此岛最后一个子岛
}
} //子岛访问完毕,开始回退
if (t == )
a[c].d2 = a[c].d1 + ;//没有下一个可以旅行的岛
else {
a[c].d2 = a[t].d2 + ;
return a[c].d2;
}
return a[c].d2;
}
int main() {
//freopen("in.txt", "r", stdin);
//freopen("out.txt", "w", stdout);
int i = ;
int j = ;
int z = ;
while (cin >> n >> m) {
if (n == && m == )
break;
for (i = ; i <= n; i++) {
for (j = ; j <= n; j++) {
maze[i][j] = ;
}
a[i].d1 = ;
a[i].d2 = ;
vist[i] = ;
}
while (m > ) {
int x;
int y;
cin >> x >> y;
maze[x][y] = ;
maze[y][x] = ;
m--;
}
//dfs
a[].d1 = ;
vist[] = ;
length = n - 1;
dfs(); //输出答案
if (z != )
printf("\n");
for (i = ; i <= n; i++) {
printf("%d", a[i].d1);
if (i + <= n)
printf(" ");
}
printf("\n");
for (i = ; i <= n; i++) {
printf("%d", a[i].d2);
if (i + <= n)
printf(" ");
}
z++;
}
return ;
}

有不懂的地方,或是有自己的想法,欢迎在下面留言!

 

ACM-世界岛旅行的更多相关文章

  1. (转)一个大牛的acm历程(看着就要颤抖)

    从我接触程序竞赛到现在应该有十多年了,单说ACM竞赛,从第一次非正式参赛到现在也差不多有7年多的样子.有太多的故事,想说的话,却一直没能有机会写下来.一方面是自己忙,一方面也是自己懒.所以很感谢能有人 ...

  2. 我的ACM参赛故事

    从我接触程序竞赛到现在应该有十多年了,单说ACM竞赛,从第一次非正式参赛到现在也差不多有7年多的样子.有太多的故事,想说的话,却一直没能有机会写下来.一方面是自己忙,一方面也是自己懒.所以很感谢能有人 ...

  3. 九度OJ 1339:ACM (排序)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:712 解决:379 题目描述: 今年的ACM世界总决赛快要开始了,需要有一个排名算法来对每支队伍进行现场排名.ACM组委会把这个任务交给了你 ...

  4. G - 旅行的意义(概率DP) (DAG图的概率与期望)

    为什么有人永远渴望旅行,或许就因为,巧合和温暖会在下一秒蜂拥而至吧. 一直想去旅游的天天决定在即将到来的五一假期中安排一场环游世界的旅行.为此,他已经提前查阅了很多资料,并准备画一张旅游路线图.天天先 ...

  5. How to Read a Book

    主题: 讲述阅读的四种层次,以及每种层次所需要的.截然不同的阅读方法. 主要声明与论点: 带着问题阅读,时刻不忘在书中寻找问题的答案: 高速阅读,以最短的时间了解一本书的全貌,然后决定是否值得再次阅读 ...

  6. [ZT] 几大酒店集团美国Co-Brand信用卡比较(三)如何选择最适合你的酒店联名信用卡

    原文地址: http://www.3798.com/archives/596.html 接着对我们这种不是某个酒店忠诚客户的用户选择卡片进行分析.首先要强调的是,我们比较的是信用卡项目本身,而不是酒店 ...

  7. python-原始字符串,长字符串

    一  长字符串 在python中要表示跨行多行的字符串,可以使用较为简单粗暴的表达-----三引号.例如: str = ”’那时我们有梦, 关于文学, 关于爱情, 关于穿越世界的旅行. 如今我们深夜饮 ...

  8. 微信公众平台-文章-app:让创意变为现实,这30个小程序“凭什么”脱颖而出?

    ylbtech-微信公众平台-文章-app:让创意变为现实,这30个小程序“凭什么”脱颖而出? 1.返回顶部 1. 让创意变为现实,这30个小程序“凭什么”脱颖而出? 微信公开课 昨天 创意1:为多种 ...

  9. HDU ACM 2066 一个人的旅行

    一个人的旅行 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

随机推荐

  1. 【51nod-1396】还是01串

    给定一个0-1串s,长度为n,下标从0开始,求一个位置k,满足0<=k<=n, 并且子串s[0..k - 1]中的0的个数与子串s[k..n - 1]中1的个数相等. 注意: (1) 如果 ...

  2. zoj3656

    题解: 按照位展开,然后一位一位判断 注意判断给出数据是否有问题 代码: #include<cstdio> #include<cmath> #include<algori ...

  3. gridview 后台增加列

    BoundField field1 = null; field1 = new BoundField();  //实例化 field1.HeaderText = "序号";field ...

  4. crypt函数加密验证

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  5. About libcurl and cURL in PHP

    今天在学习php时遇到要调用curl 库函数对特定url字符串进行访问操作,需要自己写一个方法进行调用,之前在linux系统中也有用到cURL 命令行工具执行对相关资源的获取,在wiki上找到了如下的 ...

  6. 你必须了解的Session的本质

    http://netsecurity.51cto.com/art/201402/428721.htm Cookie和session由于实现手段不同,因此也各有优缺点和各自的应用场景: 1.   应用场 ...

  7. 使用jQuery操作DOM(1)

    1.常见方法 css(“属性”,”属性值”); //设置单个样式 css({属性1:属性值1,属性2:属性值3...}); //设置多个样式 addClass(“样式名”); //追加单个样式 add ...

  8. spring之httpclient doget请求

    /**     * @param url        请求地址     * @param jsonString 加密后的字符串     * @return     * @throws ClientP ...

  9. Kconfig介绍

    https://www.kernel.org/doc/Documentation/kbuild/kconfig-language.txt

  10. live555源码分析

    live555源代码下载(VC6工程):http://download.csdn.net/detail/leixiaohua1020/6374387 liveMedia 项目(http://www.l ...