Let‘s play computer game(最短路 + dfs找出所有确定长度的最短路)
Description
xxxxxxxxx在疫情期间迷上了一款游戏,这个游戏一共有nnn个地点(编号为1——n1——n1——n),他每次从一个地点移动到另外一个地点需要消耗
一定的能量,每一个地点都有一些珠宝,输入中会把每一个地方的珠宝价值估算成一个值。
xxxxxxxxx想请聪明的你帮他找出来从编号为sss的地点,到编号为ddd的地点最小要消耗多少能量,消耗这些能量最多获得多少价值的珠宝
Input
第一行输入n,s,dn,s,dn,s,d。其意义如上描述 (n<520n<520n<520)
第二行有nnn个数XiX_iXi,比如i==1i==1i==1描述编号为1的点有珠宝价值为XiX_iXi(这里保证XiX_iXi大于等于0) (Xi<1000X_i<1000Xi<1000)
下面输入一个n∗nn*nn∗n的矩阵,比如第iii行,第j列的值为xxx,就表示从编号为iii到编号为jjj的地方距离为x (x<1000)x (x<1000)x (x<1000)(这里保证xxx大于等于0)
注意:这是一个单向路,即从编号为iii到编号为jjj的距离可能不等于从编号为jjj到编号为iii
Output
输出占一行,第一个数是最小要消耗多少能量,第二个数是消耗这些能量最多获得多少价值的珠宝。两个数用空格分开
Hint
第一个样例解释:
解释:
把这个矩阵翻译成边
1->2 1
2->4 2
1->4 3
1->3 2
3->4 2
正确路径:1->2->4
后面的就不用说了吧^_^
Source
qmh
思路
题意:一个人从 s出发到 点e,在所给的图中每个 点 就有个一个珠宝(价值会给我们的) ,在消耗能量最少(即:最短路)的基础上 求出能得到最大珠宝总价值是多少
思路:先用 Dijkstra 或者 Spfa 来求一下从 s -> e 的最短路的距离, 有了这个最短距离之后,那么我们可以用 dfs 去深搜没一条路径,找到 在所有符合最短路的路径中 价值最大的那条的价值,
注意:我们在dfs的时候是可以做优化的,让我们来看看代码中的这一段 dis[i] == dis[j] + Grf[j][i]
, dis表示的是从 s 点出发到 i 点的最短距离 Grf 是存图的临接矩阵,如果上述的 等式不成立,那么我们我们就可以不用往下递归了,因为当前走的这条路已经不可能在符合题意了,解释:假设又一条路:s -> 1 -> j -> i -> 3 -> e. | Grf[j][i] 表示从j 到 i 的距离,如果 从s 点出发到 i的距离不等于 从s出发到 dis[i] 的最短路的距离,那么它一定不可能是我们所找的最短路径,,,自己在思考思考吧
代码
#include<iostream>
#include<cstdio>
#include<queue>
using namespace std;
#define INF 0x3f3f3f3f
const int Len = 550;
int Grf[Len][Len];
int dis[Len];
int n, s, e;
int val[Len];
int Dijkstra(int s, int e)
{
int vis[Len];
for(int i = 1; i <= n; i ++)
vis[i] = 0, dis[i] = Grf[s][i];
vis[s] = 1;
for(int i = 1; i <= n; i ++)
{
int mn = INF;
for(int i = 1; i <= n; i ++) //1. 在这个集合中选择与该集合相连的最小权值的那条边的点
{
if(! vis[i] && dis[i] < mn)
{
mn = dis[i];
s = i;
}
}
//2. 把新加入的这个点做上标记
vis[s] = 1;
//3. 更新与这个点相连的边的点 dis 距离(因为在集合中的距离已经确定是最短距离,而我们在新加入这个点之后,我们可以更新与这个点相连的点(这个点是在集合外的点)的最短距离)
for(int i = 1; i <= n; i ++)
if(dis[s] + Grf[s][i] < dis[i])
dis[i] = dis[s] + Grf[s][i];
}
return dis[e];
}
int res = -1;
int mrk[Len];
void dfs(int mn_dis, int pri, int s, int e)
{
if(s == e)
{
if(res < pri)
res = pri;
return;
}
for(int i = 1; i <= n; i ++)
{
if(! mrk[i] && dis[i] == dis[s] + Grf[s][i]) //这里的 dis[i] == dis[s] + Grf[s][i] 优化避免了盲目 搜索所有路径,假设有一条路径:s -> 2 -> 3 -> e , 如果dis[3] 不等于我们dfs过程到节点3的路径长度,那么就算dfs递归到了终点,这条路径的长度也绝对不可能等于dis[e]
{
mrk[i] = 1;
dfs(mn_dis, pri + val[i], i, e);
mrk[i] = 0;
}
}
}
int main()
{
//freopen("A.txt","r",stdin);
int tem;
scanf("%d %d %d", &n, &s, &e);
for(int i = 1; i <= n; i ++)
scanf("%d", &val[i]);
for(int i = 1; i <= n; i ++)
for(int j = 1; j <= n; j ++)
scanf("%d", &tem), Grf[i][j] = tem;
int mn_dis = Dijkstra(s, e);
dfs(mn_dis, 0, s, e);
printf("%d %d\n", dis[e], res);
return 0;
}
Let‘s play computer game(最短路 + dfs找出所有确定长度的最短路)的更多相关文章
- hdu 1595 find the longest of the shortest【最短路枚举删边求删除每条边后的最短路,并从这些最短路中找出最长的那条】
find the longest of the shortest Time Limit: 1000/5000 MS (Java/Others) Memory Limit: 32768/32768 ...
- PAT-1018(Public Bike Management)最短路+额外条件+所有最短路中找出满足条件的路径+dijkstra算法
Public Bike Management PAT-1018 使用一个vector来存储所有最短路的前驱结点,再通过使用dfs和一个额外的vector记录每一条路径 #include<iost ...
- hdu1298 T9(手机输入法,每按一个数字,找出出现频率最高的字串,字典树+DFS)
Problem Description A while ago it was quite cumbersome to create a message for the Short Message Se ...
- 题目1539:师弟 ——最短路+DFS
题意::从起点到终点的所有的最短路中,找出离终点有X个路口的城市一共有几个 开始我用最短路+DFS从起点开始搜,超时了 换了一种方法,从终点开始搜,AC #include<stdio.h> ...
- ZOJ 3781 Paint the Grid Reloaded(DFS连通块缩点+BFS求最短路)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=5268 题目大意:字符一样并且相邻的即为连通.每次可翻转一个连通块X( ...
- DFS应用——找出无向图的割点
[0]README 0.1) 本文总结于 数据结构与算法分析, 源代码均为原创, 旨在 理解 "DFS应用于找割点" 的idea 并用源代码加以实现: 0.2) 必须要事先 做个s ...
- CodeForces - 103B(思维+dfs找环)
题意 https://vjudge.net/problem/CodeForces-103B 很久很久以前的一天,一位美男子来到海边,海上狂风大作.美男子希望在海中找到美人鱼 ,但是很不幸他只找到了章鱼 ...
- # 「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程)
「银联初赛第一场」自学图论的码队弟弟(dfs找环+巧解n个二元一次方程) 题链 题意:n条边n个节点的连通图,边权为两个节点的权值之和,没有「自环」或「重边」,给出的图中有且只有一个包括奇数个结点的环 ...
- [蓝桥杯2018初赛]小朋友崇拜圈(dfs找环)
传送门 思路: 题意大意:n条有向边,找出最大环. 我们发现,如果一个小朋友没有被任何人崇拜,那么他一定不位于环中.为此我们可以设置一个indug数组预处理.如果2被崇拜了那么indug[2]就加加, ...
随机推荐
- 从0到1使用MyBatis
MyBatis作为最流行的数据中间层,成为企业Java软件开发中非常重要的软件. 一.基本配置 1.首先需要导入Maven <dependency> <groupId>org. ...
- 数据加密标准(DES)详解
1 简介 1.1 历史 DES(Data Encryption Standard)是由IBM公司在1974年提出的加密算法,在1977年被NIST定位数据加密标准.随后的很多年里,DES都是最流行的对 ...
- $props, $attrs,$listeners的具体使用例子
我在这使用属性重新render饿了么ui的tree: <el-tree ref="tree" icon-class="fa fa-caret-right" ...
- Jquery 系列化表单
大家知道Jquery中有serialize方法,可以将表单序列化为一个“&”连接的字符串,但却没有提供序列化为Json的方法.不过,我们可以写一个插件实现. 我在网上看到有人用替换的方法,先用 ...
- Python基础 | 日期时间操作
目录 获取时间 时间映射 格式转换 字符串转日期 日期转字符串 unixtime 时间计算 时间偏移 时间差 "日期时间数据"作为三大基础数据类型之一,在数据分析中会经常遇到. 本 ...
- 【转】在Eclipse下,出现“找不到或无法加载主类 ”的问题的解决方式
实际上是第一次碰到这个问题,之前从来没有遇见过,于是乎就开始找“度娘”帮忙,一搜发现有很多的程序猿都遇到这个问题.网上大部分的解决方案都是说“环境变量”配置有错误,当然这确实是引发“找不到或无法加载主 ...
- 树莓派3B+安装&卸载mysql
需求 在树莓派上 安装Mysql 服务,并开启远程访问 步骤 安装 mysql server 1 $ sudo apt-get install mysql-server 我以为中间会让我提示输入 数据 ...
- Contest 153
2019-09-14 23:16:25 总体感受:节奏尚可,难度尚可.然而还是卡在了最后一题,完全没有想到使用dp. 注意点: 1)Contest的最后一题往往是DP,Graph,这个敏感度需要提高: ...
- ysoserial分析【二】7u21和URLDNS
目录 7u21 gadget链分析 hashCode绕过 参考 URLDNS 7u21 7u21中利用了TemplatesImpl来执行命令,结合动态代理.AnnotationInvocationHa ...
- 如何使用WordPress搭建网站
1.空间的申请 阿里用户可以申请[阿里共享虚拟主机普惠版6元/年],虽然配置和空间不高,但也可以做个小站点的.当不满足当前配置的时候,随时可以进行升级,所以拿来练手还是比较合适的. 2.WordP ...