题目描述:

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. Android自定义控件----RadioGroup实现APP首页底部Tab的切换

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  2. 第一章-第四题(ACM 比赛的程序是软件么? “写程序” 和 ”做软件“ 有区别么?软件工程是不是教那些不怎么会写程序的人开发软件? 你怎么看?这个游戏团队, 有很好的软件,但是商业模式和其他软件之外的因素呢?有没有考虑到)--By梁旭晖

    引用 http://baike.baidu.com/link?url=z_phkcEO4_HjFG_Lt163dGFAubdb68IbfcfzWscTOrrZ55WbJEQKzyMQ5eMQKyatD ...

  3. extjs后自己写了一些见不得人的脚本

    <html> <head> <title> 配置管理器 </title> <style type="text/css"> ...

  4. 使用PowerShell读取SharePoint里列表的内容

    1. 在https://www.microsoft.com/en-us/download/details.aspx?id=42038这里下载SharePoint Online Client Compo ...

  5. 【RabbitMQ】HelloWorld

    初识RabbitMQ RabbitMQ是一个消息代理人.它的主要目的很简单:接受并推送消息.我们可以将它理解为一个邮局:当你邮寄一封邮件到邮箱里,可以非常确定邮递员会将它送到收件人手中.打这种比方来将 ...

  6. Ubuntu使用阿里云软件源

    如果在安装Ubuntu时,选择的地区为美国,建议更新为阿里云或国内 软件源 sudo sed -i s/archive.ubuntu.com/mirrors.aliyun.com/g /etc/apt ...

  7. union的限制, 临时表大小的优化

  8. 总结-html

    页面尺寸: var w = document.body.scrollWidth; (w + "px")var h = document.body.scrollHeight; (h ...

  9. UISprite(NGUI)扩展 图片镂空

    NGUI 版本2.6.3 在做新手引导时,需要高亮特定UI元素,也就是加个黑色蒙板,然后在蒙版上显示这个UI元素,为了简单方便我扩展了下UISprite,来镂空指定空间. 分为2种,矩形和圆镂空,矩形 ...

  10. LINUX端口查看

    e切依燃   LINUX端口查看 查看文件数 ls | wc -w lsof -i:80