题目描述:

1015. Jill's Tour Paths

Constraints

Time Limit: 1 secs, Memory Limit: 32 MB

Description

Every year, Jill takes a bicycle tour between two villages. There are different routes she can take between these villages, but she does have an upper limit on the distance that she wants to travel. Given a map of the region indicating the cities and the roads between them (and their distances), Jill would like to have a list of the various routes between the selected cities that will meet her distance requirements. Your task is to write a program that will produce a list of these routes, in increasing order of distance.

We make the following assumptions.

  • At most one road connects any pair of villages, and this road is two-way and has a non-zero positive distance.
  • There are no roads that lead directly from a village back to the same village.
  • Jill is only concerned about a one-way trip. That is, she is not concerned about returning to the village from which she starts her tour.
  • Jill will not visit any village more than once during the tour.

The farthest Jill will ever travel is 9999 units

Input

The input will contain several possible cases, each including a route map, identification of the start and destination villages, and the maximum distance Jill is willing to travel.

Each case appears in the input as a set of integers separated by blanks and/or ends of lines. The order and interpretation of these integers in each case is as follows:

  • NV – the number of villages in the route map. This number will be no larger than 20.
  • NR – the number of roads that appear in the route map. Each road connects a distinct pair of villages.
  • NR triples, one for each road, containing C1, C2, and DISTC1 and C2 identify two villages connected by a road, and DIST gives the distance between these villages on that road.
  • SV, DV – the numbers associated with the start and destination villages; the villages are numbered 1 to NV.
  • MAXDIST – the maximum distance Jill is willing to travel (one way).

The data for the last case will be followed by a single integer with the value –1.

Output

For each case, display the case number (1, 2, …) on the first line of output. Then, each on a separate additional line, list the routes that Jill might take preceded by the length of the route. Order the routes first by length, from shortest to longest. Within routes having the same length, order them in increasing lexicographic order. The sample input and output provide suitable examples, and the formatting shown there should be followed closely (each village number should be separated by a single space). Separate the output for consecutive cases by a single blank line. If there is no route, print out " NO ACCEPTABLE TOURS"(notice there is one space at the front).

Sample Input

4 5

1 2 2

1 3 3

1 4 1

2 3 2

3 4 4

1 3

4

4 5

1 2 2

1 3 3

1 4 1

2 3 2

3 4 4

1 4

10

5 7

1 2 2

1 4 5

2 3 1

2 4 2

2 5 3

3 4 3

3 5 2

1 3

8

5 7

1 2 2

1 4 5

2 3 1

2 4 2

2 5 3

3 4 3

3 5 2

1 3

1

-1

Sample Output

Case 1:

 3: 1 3

 4: 1 2 3

Case 2:

 1: 1 4

 7: 1 3 4

 8: 1 2 3 4

Case 3:

 3: 1 2 3

 7: 1 2 4 3

 7: 1 2 5 3

 8: 1 4 2 3

 8: 1 4 3

Case 4:

 NO ACCEPTABLE TOURS

题目分析:

比较简单的一道题,要求求出两点之间小于最大长度的所有路径,用深搜和广搜都可以解决,要注意深搜时在回溯的时候一定要记得将数据恢复到上一次搜索前的状态。以下是深搜的实现。

代码实现:

#include <iostream>
#include <algorithm>
#include <vector>
#include <string.h>
using namespace std; struct sol {
sol(){}
int route[];
int size;
int dista;
};
vector<sol> sols;
bool visited[];
int adj[][];
int path[][];
int adjs[];
int r[];
int j, src, dist, len, maxr; // init void calP() {
int i;
sol one;
one.size = j;
one.dista = len;
for (i = ; i < one.size; i++) {
one.route[i] = r[i];
}
sols.push_back(one);
}
void dfs(int now) {
if (now == dist) {
calP();
return;
}
int i, l;
l = adjs[now];
for (i = ; i < l; i++) {
if (!visited[adj[now][i]]) {
r[j++] = adj[now][i];
visited[adj[now][i]] = true;
len += path[now][adj[now][i]];
if (len <= maxr) {
dfs(adj[now][i]);
}
len -= path[now][adj[now][i]];
visited[adj[now][i]] = false;
j--;
}
}
}
bool cmp(const sol& a, const sol& b) {
if (a.dista > b.dista) {
return false;
}
if (a.dista == b.dista) {
int minl = a.size;
int i;
if (minl > b.size) {
minl = b.size;
}
for (i = ; i < minl; i++) {
if (a.route[i] > b.route[i])
return false;
if (a.route[i] < b.route[i])
return true; }
return a.size < b.size;
}
return true;
}
int main() {
int nv, nr, i, f, t, d, ncase = , k;
while (cin >> nv && nv != -) {
cin >> nr;
sols.clear();
memset(path, , sizeof(path));
memset(adj, , sizeof(adj));
memset(adjs, , sizeof(adjs));
memset(visited, , sizeof(visited));
for (i = ; i < nr; i++) {
cin >> f >> t >> d;
adj[t][adjs[t]++] = f;
adj[f][adjs[f]++] = t;
path[t][f] = path[f][t] = d;
}
cin >> src >> dist;
cin >> maxr;
j = len = ;
visited[src] = true;
r[j++] = src;
dfs(src);
sort(sols.begin(), sols.end(), cmp);
if (ncase != ) {
cout << endl;
}
cout << "Case " << ++ncase << ":\n";
for (i = ; i < sols.size(); i++) {
cout << " " << sols[i].dista << ":";
for (k = ; k < sols[i].size; k++) {
cout << " " << sols[i].route[k];
}
cout << endl;
}
if (sols.size() == ) {
cout << " NO ACCEPTABLE TOURS" << endl;
}
}
}

复杂度:

图的节点数为V,边数为E, 解个数为n。

时间:初始化(E) + 深搜(E*V) + 排序(n*lg(n))

空间:V^2

标签:

深搜

soj 1015 Jill's Tour Paths 解题报告的更多相关文章

  1. 【九度OJ】题目1015:还是A+B 解题报告

    [九度OJ]题目1015:还是A+B 解题报告 标签(空格分隔): 九度OJ http://ac.jobdu.com/problem.php?pid=1015 题目描述: 读入两个小于10000的正整 ...

  2. 【LeetCode】257. Binary Tree Paths 解题报告(java & python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 递归 迭代 日期 题目地址:https://leet ...

  3. 【LeetCode】576. Out of Boundary Paths 解题报告(Python)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 目录 题目描述 题目大意 解题方法 动态规划 状态搜索 记忆化搜索 相似题目 参考资料 ...

  4. 【LeetCode】62. Unique Paths 解题报告(Python & C++)

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 题目地址:https://leetcode.com/problems/unique-pa ...

  5. LeetCode: Unique Paths 解题报告

    A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...

  6. 洛谷 P2860 [USACO06JAN]冗余路径Redundant Paths 解题报告

    P2860 [USACO06JAN]冗余路径Redundant Paths 题目描述 为了从F(1≤F≤5000)个草场中的一个走到另一个,贝茜和她的同伴们有时不得不路过一些她们讨厌的可怕的树.奶牛们 ...

  7. LeetCode: Unique Paths II 解题报告

    Unique Paths II Total Accepted: 31019 Total Submissions: 110866My Submissions Question Solution  Fol ...

  8. LeetCode 解题报告索引

    最近在准备找工作的算法题,刷刷LeetCode,以下是我的解题报告索引,每一题几乎都有详细的说明,供各位码农参考.根据我自己做的进度持续更新中......                        ...

  9. [置顶] 刘汝佳《训练指南》动态规划::Beginner (25题)解题报告汇总

    本文出自   http://blog.csdn.net/shuangde800 刘汝佳<算法竞赛入门经典-训练指南>的动态规划部分的习题Beginner  打开 这个专题一共有25题,刷完 ...

随机推荐

  1. PHP的流程控制结构

    1.break 使用break语句可以将深埋在嵌套循环中的语句退出到指定层数或直接退出到最外层,break是接受一个可选的数字参数来决定跳出几重语句.break可以跳出几重语句.break可以跳出几重 ...

  2. 【iCore3双核心板】发布 iCore3 应用开发平台硬件原理图

     原理图PDF下载地址:http://pan.baidu.com/s/1jHY0hNK iCore3应用开发平台购买地址:https://item.taobao.com/item.htm?spm=a1 ...

  3. 改变spring-servlet.xml名字和默认位置

    如何我们在web.xml定义: <servlet> <servlet-name>spring</servlet-name> <servlet-class> ...

  4. Java实现MySQL数据库导入

    距离上班还有一段时间.现在总结一下如何使用Java语言实现MySQL数据库导入: 首先新建名为test的数据库: 其次执行下面Java代码: import java.io.File; import j ...

  5. 修改SQL SERVER表,并添加说明

    alter table dbo.user_PersonManagement add F_FGBM nvarchar(500)GO EXEC sys.sp_addextendedproperty @na ...

  6. P1220 关路灯

    #include <bits/stdc++.h> using namespace std; int d[100], w[100], s, n; int dp[100][100][3]; i ...

  7. [flex布局]-flex教程

    简介:2009年,W3C提出了一种新的方案----Flex布局,可以简便.完整.响应式地实现各种页面布局.目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能. Flex布局是什 ...

  8. CSS之viewport 2

    在这个迷你系列的文章里边我将会解释viewport,以及许多重要元素的宽度是如何工作的,比如<html>元素,也包括窗口和屏幕. 这篇文章我们来聊聊关于移动浏览器的内容.如果你对移动开发完 ...

  9. 自定义NSLog

    我们在调试程序的时候,往往需要输出一些日志信息,用到NSLog函数,当我们准备发布程序,需要注释掉NSLog代码,这个时候往往会定义一个宏,在调试的时候,会输出日志,在Release正式版本的时候,会 ...

  10. MQTT——服务器搭建(一)

    MQTT介绍 MQTT,是IBM推出的一种针对移动终端设备的基于TCP/IP的发布/预订协议,可以连接大量的远程传感器和控制设备: 轻量级的消息订阅和发布(publish/subscribe)协议 建 ...