pat1003 迪杰斯特拉法和dfs求最短路
本题的背景是求定点和定点之间的最短路问题(所有的最短路 不是一个解 是全部解,方法手段来自数据结构课程中的迪杰斯特拉算法和dfs(深度优先遍历)。
分别用两种方法编程如下代码
- dfs
#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
#define maxv 510
bool visit[maxv]; int arc[maxv][maxv];//邻接矩阵 int M,N,C1,C2; //M总顶点数,N总边数,C1起点,C2终点 int vex[maxv]; //记录每个顶点的救援人数 int mind=0xfffffff,maxr=0,cnt;//mind最短路径,maxr最大救援人数,cnt最短路径条数 void dfs(int st,int end,int curPath,int curRes){
if (st==end){
if (curPath<mind){
cnt=1;
mind=curPath;
maxr=curRes;
}else if(curPath==mind){
cnt++;
if (curRes>maxr)
maxr=curRes;
}
return;
}
else{
for (int k=0;k<M;k++){
if (arc[st][k]!=0&&!visit[k]){
visit[k]=1;
dfs(k,end,curPath+arc[st][k],curRes+vex[k]);
visit[k]=0;
}
}
return ;
}
}
int main(){
while(scanf("%d%d%d%d",&M,&N,&C1,&C2)!=EOF){
memset(arc,0,sizeof(arc));
for(int i=0;i<M;i++)
scanf("%d",&vex[i]);
int i,j,d;
for(int k=0;k<N;k++){
scanf("%d%d%d",&i,&j,&d);
arc[j][i]=arc[i][j]=d;
}
memset(visit,0,sizeof(visit));
visit[C1]=1;
dfs(C1,C2,0,vex[C1]);
printf("%d %d",cnt,maxr);
}
return 0;
}
- 容易放的错误是mind,maxr忘记赋初始值
- 矩阵scanf输入的时候&arg[i][j] 不会报错 但会导致输入异常 这个问题我也很奇怪 先在这里记录说明了
- 迪杰斯特拉算法
#include <iostream>
#include <cstdio>
using namespace std;
#define maxv 510
#define inf 65536 int arc[maxv][maxv];//邻接矩阵 int M,N,C1,C2; //M总顶点数,N总边数,C1起点,C2终点 int vex[maxv]; //记录每个顶点的救援人数 int maxr=0,cnt;//mind最短路径,maxr最大救援人数,cnt最短路径条数 int Path[maxv],D[maxv],S[maxv];
//Path[]记录从源点v0到终点vi的直接前驱顶点序号
//D[]记录从源点v0到终点vi的当前最短路径长度
//S[]记录从源点v0到源点vi是否已经被确定最短路径长度 /*计算v0到j的当前最大救援人数*/
void compute(int v0,int j){
int curRes=vex[v0];
for (int k=j;k!=v0;k=Path[k]){
curRes+=vex[k];
}
if (curRes>maxr)
maxr=curRes;
return;
} void dijistra(int v0,int v){
int mind,w;
//mind最短路径 w被加入到S中的顶点序号 int curRes=0;
/*初始化*/
for (int i=0;i<M;i++){
S[i]=false;
D[i]=arc[v0][i];
if (D[i]<inf)
Path[i]=v0;
else
Path[i]=-1;
}
cnt=1;
compute(v0,v);
S[v0]=true;
D[v0]=0; /*v0到其他M-1个顶点的最短路径*/
for (int i=1;i<M;i++){
mind=inf;
for (int j=0;j<M;j++)
if (!S[j]&&D[j]<mind){
w=j;mind=D[j];
}
S[w]=true;
for (int j=0;j<M;j++)
if (!S[j]&&(D[w]+arc[w][j]<D[j])){
D[j]=D[w]+arc[w][j];
Path[j]=w;
if (j==v){
cnt=1;
maxr=0;
compute(v0,j);
}
}else if (!S[j]&&D[w]+arc[w][j]==D[j]){
Path[j]=w;
if (j==v){
cnt++;/*v0到顶点j的当前最短路径不止一条*/
compute(v0,j);
}
}
}
return;
}
int main(){
while(scanf("%d%d%d%d",&M,&N,&C1,&C2)!=EOF){
for (int i=0;i<M;i++)
for (int j=0;j<M;j++)
arc[i][j]=inf;
for(int i=0;i<M;i++)
scanf("%d",&vex[i]);
int i,j,d;
for(int k=0;k<N;k++){
scanf("%d%d%d",&i,&j,&d);
arc[j][i]=arc[i][j]=d;
}
dijistra(C1,C2);
printf("%d %d\n",cnt,maxr);
//printf("%d %d %d %d %d\n",cnt,maxr,D[C2],Path[C2],Path[Path[C2]]);
/*for (int i=0;i<M;i++){
for (int j=0;j<M;j++)
printf("%d ",arc[i][j]);
printf("\n");
}*/
}
return 0;
}
这段代码目前只能通过pat平台的三个测试样例 得 16分 后续会 改bug
pat1003 迪杰斯特拉法和dfs求最短路的更多相关文章
- 算法基础⑧搜索与图论--dijkstra(迪杰斯特拉)算法求单源汇最短路的最短路径
单源最短路 所有边权都是正数 朴素Dijkstra算法(稠密图) #include<cstdio> #include<cstring> #include<iostream ...
- 迪杰斯特拉(Dijkstra) 最短路算法
直接看B站视频吧: https://www.bilibili.com/video/BV1QK411V7V4/
- ACM-ICPC 2018 南京赛区网络预赛 - L Magical Girl Haze (分层迪杰斯特拉)
题意:N个点,M条带权有向边,求可以免费K条边权值的情况下,从点1到点N的最短路. 分析:K<=10,用dist[i][j]表示从源点出发到点i,免费j条边的最小花费.在迪杰斯特拉的dfs过程中 ...
- POJ 2502 Subway(迪杰斯特拉)
Subway Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 6692 Accepted: 2177 Descriptio ...
- 单源最短路径-迪杰斯特拉算法(Dijkstra's algorithm)
Dijkstra's algorithm 迪杰斯特拉算法是目前已知的解决单源最短路径问题的最快算法. 单源(single source)最短路径,就是从一个源点出发,考察它到任意顶点所经过的边的权重之 ...
- PAT 1087 All Roads Lead to Rome[图论][迪杰斯特拉+dfs]
1087 All Roads Lead to Rome (30)(30 分) Indeed there are many different tourist routes from our city ...
- C++迪杰斯特拉算法求最短路径
一:算法历史 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以 ...
- 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 ...
- hdu 1142(迪杰斯特拉+记忆化搜索)
A Walk Through the Forest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Jav ...
随机推荐
- APP偏移地址
配合BootLoader的APP程序 SCB->VTOR = 0x0803C004; 这里最后还要加上4的原因是 向量表的复位向量地址是4 0地址存的是栈顶
- Jmeter正则表达式提取器
https://www.cnblogs.com/tudou-22/p/9566894.html Jmeter中关联是通过“添加—后置处理器—正则表达式提取器”来获取数据 一.获取单个数据
- POI导出excel列宽自适应
让单元格宽度随着列和单元格值的宽度自适应: //存储最大列宽 Map<Integer, Integer> maxWidth = new HashMap<>(); // 将列头设 ...
- U盘挂载指令
相关步骤来自于百度 1.先确定U盘格式,如果是ntfs格式,需要先安装3g-ntfs这个软件支持ntfs格式,以下默认U盘为fat32格式 2.使用fdisk -l 查看分区表,找到u盘的设备号,比如 ...
- Windows下安装使用python的Flask框架
1.安装python环境: 这里就不赘述了. 2.安装virtualenv虚拟环境: 这里使用使用第三方工具 virtualenv 创建虚拟环境.虚拟环境的好处如下(摘录网络): “ 安装 Flask ...
- DDD关键知识点整理汇总
创建领域对象采用构造函数或者工厂,如果用工厂时需要依赖于领域服务或仓储,则通过构造函数注入到工厂: 一个聚合是由一些列相联的Entity和Value Object组成,一个聚合有一个聚合根,聚合根是E ...
- fork()相关的源码解析
fork()的真正执行采用的是do_fork()函数,所以下文将从do_fork()函数对fork()进行源码解析.下图是do_fork()的源码函数设计: 从上图我们可以看到do_fork()涉及到 ...
- 蓝桥杯近3年决赛题之3(17年b组)
做的时候对了2个小题,一个大题可能会拿点分数. 1. 标题:36进制 对于16进制,我们使用字母A-F来表示10及以上的数字.如法炮制,一直用到字母Z,就可以表示36进制. 36进制中,A表示10,Z ...
- Fastcgi、CGI 是什么
1.CGI是干嘛的?CGI是为了保证web server传递过来的数据是标准格式的,方便CGI程序的编写者. 2.web server(比如说nginx)只是内容的分发者. 比如,如果请求/index ...
- sql中批量插入begin的使用
private static String ADD_ATTR_EXT_ITEM="insert into attr_ext_item(attr_ext_main_key,attr_name_ ...