本题的背景是求定点和定点之间的最短路问题(所有的最短路 不是一个解  是全部解,方法手段来自数据结构课程中的迪杰斯特拉算法和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;
}
  1. 容易放的错误是mind,maxr忘记赋初始值    
  2. 矩阵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求最短路的更多相关文章

  1. 算法基础⑧搜索与图论--dijkstra(迪杰斯特拉)算法求单源汇最短路的最短路径

    单源最短路 所有边权都是正数 朴素Dijkstra算法(稠密图) #include<cstdio> #include<cstring> #include<iostream ...

  2. 迪杰斯特拉(Dijkstra) 最短路算法

    直接看B站视频吧: https://www.bilibili.com/video/BV1QK411V7V4/

  3. ACM-ICPC 2018 南京赛区网络预赛 - L Magical Girl Haze (分层迪杰斯特拉)

    题意:N个点,M条带权有向边,求可以免费K条边权值的情况下,从点1到点N的最短路. 分析:K<=10,用dist[i][j]表示从源点出发到点i,免费j条边的最小花费.在迪杰斯特拉的dfs过程中 ...

  4. POJ 2502 Subway(迪杰斯特拉)

    Subway Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 6692   Accepted: 2177 Descriptio ...

  5. 单源最短路径-迪杰斯特拉算法(Dijkstra's algorithm)

    Dijkstra's algorithm 迪杰斯特拉算法是目前已知的解决单源最短路径问题的最快算法. 单源(single source)最短路径,就是从一个源点出发,考察它到任意顶点所经过的边的权重之 ...

  6. 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 ...

  7. C++迪杰斯特拉算法求最短路径

    一:算法历史 迪杰斯特拉算法是由荷兰计算机科学家狄克斯特拉于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图中最短路径问题.迪杰斯特拉算法主要特点是以 ...

  8. 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 ...

  9. hdu 1142(迪杰斯特拉+记忆化搜索)

    A Walk Through the Forest Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Jav ...

随机推荐

  1. SCRIPT438: 对象不支持“indexOf”属性或方法

    SCRIPT438: 对象不支持“indexOf”属性或方法 indexOf()的用法:返回字符中indexof(string)中字串string在父串中首次出现的位置,从0开始!没有返回-1:方便判 ...

  2. Cutting Codeforces Round #493 (Div. 2)

    Cutting There are a lot of things which could be cut — trees, paper, “the rope”. In this problem you ...

  3. mysql distinct()用法

    在使用mysql时,有时需要查询出某个字段不重复的记录,虽然mysql提供有distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所 ...

  4. matlab中CRC的函数使用

    先学习一下matlab中CRC函数. 语法如下: h = crc.generator(‘Polynomial', polynomial, ‘param1', val1, etc.) 再看一个例子就比较 ...

  5. Cross-Origin跨域问题

    为什么会跨域,要先了解浏览器的同源策略SOP(Same Orign Policy)  https://segmentfault.com/a/1190000015597029 同源: 如果两个页面的协议 ...

  6. python报错记录

    1.AttributeError: 'NoneType' object has no attribute 'group' import re s=r'<title>kobe<\tit ...

  7. python 小试一题

    a = 66count = 1while count <=3 : b = int(input("猜测这个数字:")) if b < a: print("猜测的 ...

  8. stm32高级定时器的应用——spwm

    用过stm32定时器的朋友都知道,定时器的CCR寄存器,可以用来配置PWM的输出,但同样也可以用来配置spwm.废话不多说,直接上代码. 首先,你得考虑一下几个因素: 1.同步调制还是异步调制.  2 ...

  9. 20.C# 创建自己的泛型类型

    1.定义泛型类 可以使用以下语法创建泛型类,T可以是任意符合C#标识符命名规范的任意标识符 class MyGenericClass<T> { //.... } 泛型类可以包含任意多个类型 ...

  10. iOS组件化之路(一)

    写在最前 从开始学写代码,胡乱的看书,不懂如何写第一个程序,到开始写出第一个程序,这段道路有些漫长.慢慢开始自己独立的去分析给出的需求,到如何实现,最初的想法只是仅仅实现,到后来懂得如何利用自己技术和 ...