poj 1724 ROADS 解题报告
题目链接:http://poj.org/problem?id=1724
题目意思:给出一个含有N个点(编号从1~N)、R条边的有向图。Bob 有 K 那么多的金钱,需要找一条从顶点1到顶点N的路径(每条边需要一定的花费),前提是这个总花费 <= K.
首先这里很感谢 yunyouxi0 ,也就是我们的ACM队长啦~~~,他一下子指出了我的错误——存储重边的错误。这条题卑鄙的地方是,有重边,discuss 中的数据过了也不一定会AC啦。大家不妨试试这组数据(队长深情奉献^_^)
2
2
2
1 2 2 3
1 2 3 2
ans: 3
用邻接表来存储就可以解决这个问题啦。看了差不多整天的邻接表,终于看懂了,大感动啊^__^。对于初次使用的我(或者其他也是第一次接触的读者),希望这幅图能帮大家理解理解~~~~

我用Sample 来解释这幅图
5
6
7
1 2 2 3
2 4 3 3
3 4 2 4
1 3 4 1
4 6 2 1
3 5 2 0
5 4 3 2
建立一个邻接表
struct adj_table // 邻接表
{
int next, D, L, T;
}node[M];
首先这个F[i] 表示对于编号为 i 这个 点中跟它相邻的点有多少个,也就是表头!
那些0、3、1、...、5的意思实质就是第几行输入,假设是3 5 2 0, 是图中的数字 5了,对于3这个点来说,如果还有一条从点3出发的边,那么下一次插入就从这个 5 开始。
可能我还是说得不清不楚啦~~~,结合这个运行结果还有上面那幅本人呕心沥血图来看,是不是一下子豁然开朗呢?注意 j = 3(v = 3) 之后,下一个点是node[3].next ,也就是 0(v = 2),由于我们在插入的时候,node[3].D 已经把目标节点记录下来了,还有长度和花费,所以不断往返的时候,就能求出所有跟 j = 3 的所有相邻节点了(再下一个是 node[0].next ,为-1 就停止了,代表已经到达头结点:编号为1的点,刚好对于节点1来说, 2, 3 就是跟它邻接的点,由于是回溯回去的,所以先输出3, 再输出2)

(first 点 6 结束了,因为从6出发没有路!)
#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std; const int INF = ;
const int M = + ;
const int maxn = + ;
struct adj_table // 邻接表
{
int next, D, L, T;
}node[M]; // 不要开小了!!!写成maxn会runtime error int F[maxn]; // 表头
int vis[maxn]; int K, N, R, flag, minlen; void dfs(int head, int r, int l)
{
if (l > minlen) // 剪枝,防止TLE的关键
return;
if (head == N && r >= )
{
flag = ;
minlen = min(minlen, l);
return;
}
for (int i = F[head]; i != -; i = node[i].next)
{
int v = node[i].D;
if (!vis[v]&& r-node[i].T >= ) // 未走过+费用足
{
vis[v] = ;
dfs(v, r-node[i].T, l+node[i].L); // 注意:不是r-node[v].T和l+node[v].L, 因为是指向下一个顶点, v是当前顶点
vis[v] = ;
}
}
} int main()
{
while (scanf("%d%d%d", &K, &N, &R) != EOF)
{
int s, d, l, t;
int count = ;
memset(vis, , sizeof(vis));
memset(F, -, sizeof(F));
for (int i = ; i < R; i++)
{
scanf("%d%d%d%d", &s, &d, &l, &t);
node[count].next = F[s];
node[count].D = d, node[count].L = l, node[count].T = t;
F[s] = count++;
}
vis[] = ;
minlen = INF, flag = ;
dfs(, K, );
printf("%d\n", !flag ? - : minlen);
}
return ;
}
poj 1724 ROADS 解题报告的更多相关文章
- 深搜+剪枝 POJ 1724 ROADS
POJ 1724 ROADS Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 12766 Accepted: 4722 D ...
- POJ 2002 Squares 解题报告(哈希 开放寻址 & 链式)
经典好题. 题意是要我们找出所有的正方形.1000点,只有枚举咯. 如图,如果我们知道了正方形A,B的坐标,便可以推测出C,D两点的坐标.反之,遍历所有点作为A,B点,看C,D点是否存在.存在的话正方 ...
- poj 2421 Constructing Roads 解题报告
题目链接:http://poj.org/problem?id=2421 实际上又是考最小生成树的内容,也是用到kruskal算法.但稍稍有点不同的是,给出一些已连接的边,要在这些边存在的情况下,拓展出 ...
- 【原创】poj ----- 1182 食物链 解题报告
题目地址: http://poj.org/problem?id=1182 题目内容: 食物链 Time Limit: 1000MS Memory Limit: 10000K Total Submi ...
- POJ 1724 ROADS(使用邻接表和优先队列的BFS求解最短路问题)
题目链接: https://cn.vjudge.net/problem/POJ-1724 N cities named with numbers 1 ... N are connected with ...
- poj 1724 ROADS 很水的dfs
题意:给你N个城市和M条路和K块钱,每条路有话费,问你从1走到N的在K块钱内所能走的最短距离是多少 链接:http://poj.org/problem?id=1724 直接dfs搜一遍就是 代码: # ...
- poj 2051.Argus 解题报告
题目链接:http://poj.org/problem?id=2051 题目意思:题目有点难理解,所以结合这幅图来说吧---- 有一个叫Argus的系统,该系统支持一个 Register 命令,输入就 ...
- poj 1102.LC-Display 解题报告
题目链接:http://poj.org/problem?id=1102 题目意思:就是根据给出的格式 s 和 数字 n,输出数值 n 的 LCD 显示.数值 n 的每个数字要占据 s + 2 列 和 ...
- poj 1724:ROADS(DFS + 剪枝)
ROADS Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10777 Accepted: 3961 Descriptio ...
随机推荐
- Python入门--14--字典
基础知识: 0.python对值没有要求,但对key有些要求,必须是非变量(变量,列表,字典) 1.在列表中使用成员资格操作符,和在字典中使用成员资格操作符,后者会更快 2.fromkeys这个函数会 ...
- Lucene 6.5.0 入门Demo(2)
参考文档:http://lucene.apache.org/core/6_5_0/core/overview-summary.html#overview.description 对于path路径不是很 ...
- Python中%r与%s的区别
%r是rper()方法处理的对象 %s是str()方法处理的对象 其实有些情况下,两者处理的结果是一样的,比如说处理数据类型为int型对象: 例如1: print ('I am %d year old ...
- android 服务
1.创建服务 Exported:是否允许除了当前程序之外的其他程序访问这个服务 Enable:是否启用这个服务 点击完成后自动生成 import android.app.Service; import ...
- luogu P2912 [USACO08OCT]牧场散步Pasture Walking
题目描述 The N cows (2 <= N <= 1,000) conveniently numbered 1..N are grazing among the N pastures ...
- IO流(1)-键盘录入学生信息(姓名,语文成绩,数学成绩,英语成绩),按照总分从高到低存入文本文件
1.先写一个Student类 public class Student { private String name; private int chinese; private int math; pr ...
- gorm 结构体 预加载
结构体构建 type PlansApproval struct { ID uint Plans_Id int //plans编号 UpdateUser int //更新者 ...
- Java搜索引擎选择: Elasticsearch与Solr(转)
Elasticsearch简介 Elasticsearch是一个实时的分布式搜索和分析引擎.它可以帮助你用前所未有的速度去处理大规模数据. 它可以用于全文搜索,结构化搜索以及分析,当然你也可以将这三者 ...
- 使用NSOperationQueue简化多线程开发
多线程开发是一件需要特别精心的事情,即使是对有多年开发经验的工程师来说. 为了能让初级开发工程师也能使用多线程,同时还要简化复杂性.各种编程工具提供了各自的办法.对于iOS来说,建议在尽可能的情况下避 ...
- Yii Criteria常用方法(select,join,where,日期,)
$criteria = new CDbCriteria; //select $criteria->select = '*';//默认* $criteria->select = 'id,n ...