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 ...
随机推荐
- RRAS
远程访问控制是Windows NT.Win200x Server提供的一种远程服务,它允许用户从远端通过拨号连接连接到一个本地的计算机网络,一旦建立了连接,就相当于处在了本地的LAN中,从而可以使用各 ...
- msp430项目编程51
msp430综合项目---扩展项目一51 1.电路工作原理 2.代码(显示部分) 3.代码(功能实现) 4.项目总结
- android实现通知栏消息
一.原理 消息推送有两种,一种是客户端定时直接到服务器搜索消息,如果发现有新的消息,就获取消息下来:另一种是服务器向客户端发送消息,也就是当有信息消息时,服务器端就会向客户端发送消息. 二.步骤(代码 ...
- 快速掌握RabbitMQ(四)——两种消费模式和QOS的C#实现
本篇介绍一下RabbitMQ中的消费模式,在前边的所有栗子中我们采用的消费者都是EventingBasicConsumer,其实RabbitMQ中还有其他两种消费模式:BasicGet和QueueBa ...
- BZOJ1017魔兽地图DotR 樹形DP
@(BZOJ)[樹形DP, 三維DP] Description DotR (Defense of the Robots) Allstars是一个风靡全球的魔兽地图,他的规则简单与同样流行的地图DotA ...
- python把日期转换为秒数;日期转为字符串;datetime、date
1.秒数是相对于1970.1.1号的秒数 2.日期的模块有time.datetime 3. import datetime t = datetime.datetime(2009, 10, 21, 0, ...
- start memcached
memcached -m 64 -p 11211 -u fly -l 127.0.0.1 ------------------------------------------------------- ...
- Dubbo简单介绍及实例
1.概念 Dubbo是一个分布式服务框架,以及阿里巴巴内部的SOA服务化治理方案的核心框架.其功能主要包含:高性能NIO通讯及多协议集成.服务动态寻址与路由.软负载均衡与容错,依赖分析与降级等. 说通 ...
- vue 实现 扫二维码 功能
前段时间一直在研究,如何通过 vue 调用 相机 实现 扫一扫的功能,但是查看文档发现,需要获取 getUserMedia 的属性值,但存在兼容性问题. 退而求其次,通过 h5plus 来实现. 1. ...
- MySQL之常见问题总结
MySQL总是崩溃 首先你应该试着找出问题MySQLd守护进程是否死掉或你的问题是否与你的客户有关.你能够用MySQLadmin version检查你的MySQLdserver正常运行了多长时间.假设 ...