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]就加加, ...
随机推荐
- 微信小程序转化为uni-app项目
前言: 之前自己做一个uni-app的项目的时候前端需要实现一个比较复杂的功能,但是由于自己前端抠脚的原因没有写出来,然后自己在网上搜索的时候发现了有个微信小程序里面的页面及其的符合我的需求.那么问题 ...
- HashMap 速描
HashMap 速描 之前简单的整理了Java集合的相关知识,发现HashMap并不是三言两语能够讲明白的,所以专门整理一下HashMap的相关知识. HashMap 存储结构 HashMap是一个哈 ...
- 爬虫之requestsku
想用selenium实现B站自动登录已经点赞等功能,看到如何解决滑动解锁有关爬虫的内容,便开始学习爬虫,没过多久又想把记录自己生活的网站做起来,朋友便推荐了layui框架倒腾了一晚上自我觉得是做后台系 ...
- SQL Server 存储过程 函数 和sql语句 区别
存储过程与sql语句 存储过程的优点: 1.具有更好的性能 存储过程是预编译的,只在创建时进行编译,以后每次执行存储过程都不需再重新编译, 而一般 SQL 语句每执行一次就编译一次,因此使用存 ...
- Android平台接入OneNET
1. OneNET简介 中国移动物联网开放平台是由中国移动打造的PaaS物联网开放平台. 平台能够帮助开发者轻松实现设备接入与设备连接,提供综合性的物联网解决方案,实现物联网设备的数据获取,数据存储, ...
- 用 SendGrid 发送免费电子邮件
1. 概述 SendGrid 免费账号可以限额发送 100/天封邮件,虽然比 Mailgun 的每月 10000 封的免费额度少,但胜成注册无需绑定信息卡. 集成 SendGrid 有 SMTP 和 ...
- 对时间进行操作 加减 XXX天
date:要操作的时间目标 days: 要加减的天数时间 addDate: function(date, days) { if (date == '') { return '' }; if (days ...
- webStorm -> Version Control _> Repository -> Filter By User 查看svn日志
webStorm -> Version Control _> Repository -> Filter By User 查看svn日志
- 为了弄懂Flutter的状态管理, 我用10种方法改造了counter app
为了弄懂Flutter的状态管理, 我用10种方法改造了counter app 本文通过改造flutter的counter app, 展示不同的状态管理方法的用法. 可以直接去demo地址看代码: h ...
- win7 win10 更换电脑盘符的图标
效果如下 第一步 -> 1.把文件全放到盘符住目录 2.如果需要更换图标 (文件最好是ICO后缀的) 打开 Autorun 文件并编辑 第二步 -> 重启电脑就完了 下载连接 已经放到码 ...