Dijkstra算法_最短路径_L2-001. 紧急救援
作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图。在地图上显示有多个分散的城市和一些连接城市的快速道路。每个城市的救援队数量和每一条连接两个城市的快速道路长度都标在地图上。当其他城市有紧急求助电话给你的时候,你的任务是带领你的救援队尽快赶往事发地,同时,一路上召集尽可能多的救援队。
输入格式:
输入第一行给出4个正整数N、M、S、D,其中N(2<=N<=500)是城市的个数,顺便假设城市的编号为0~(N-1);M是快速道路的条数;S是出发地的城市编号;D是目的地的城市编号。第二行给出N个正整数,其中第i个数是第i个城市的救援队的数目,数字间以空格分隔。随后的M行中,每行给出一条快速道路的信息,分别是:城市1、城市2、快速道路的长度,中间用空格分开,数字均为整数且不超过500。输入保证救援可行且最优解唯一。
输出格式:
第一行输出不同的最短路径的条数和能够召集的最多的救援队数量。第二行输出从S到D的路径中经过的城市编号。数字间以空格分隔,输出首尾不能有多余空格。
输入样例:
4 5 0 3
20 30 40 10
0 1 1
1 3 2
0 3 3
0 2 2
2 3 2
输出样例:
2 60
0 1 3 这道题说白了就是寻找最短路径,但是由于pat平台很蠢,很蠢很蠢,对JAVA支持很差,跑一个syso都要100ms!这种算法题你要我200ms做完?
迫于无奈 用java和C分别实现了一边,效率不提了


这两个代码的核心思路是完全一样的,pat这个平台对于java,有的时候还需要用BufferedReader来接受,用scanner会超时,我真的是无话可说。
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays; public class Main { static int MAXVEX ;
static int INFINITY = 65535;
static int[] Pathmatirx;
static int[] ShortPathTable;
static int[][] graph;
static int[] Spnum;
static int[] nums;
static int[] values;
public static void main(String[] args) throws IOException {
BufferedReader bReader = new BufferedReader(new InputStreamReader(System.in));
String[] string = bReader.readLine().split(" ");
int n = Integer.parseInt(string[0]);
int m = Integer.parseInt(string[1]);
int s = Integer.parseInt(string[2]);
int d = Integer.parseInt(string[3]);
nums = new int[n];
MAXVEX = n;
Pathmatirx = new int[MAXVEX];
ShortPathTable = new int[MAXVEX];
graph = new int[MAXVEX][MAXVEX];
Spnum = new int[MAXVEX];
for (int i = 0; i < MAXVEX; i++) {
Arrays.fill(graph[i], INFINITY);
graph[i][i] = 0;
}
string = bReader.readLine().split(" ");
for (int i = 0; i < n; i++) {
nums[i] = Integer.parseInt(string[i]);
}
for (int i = 0; i < m; i++) {
string = bReader.readLine().split(" ");
int t1 = Integer.parseInt(string[0]);
int t2 = Integer.parseInt(string[1]);
int t3 = Integer.parseInt(string[2]);
graph[t1][t2] = t3;
}
for (int i = 0; i < MAXVEX; i++) {
for (int j = 0; j < MAXVEX; j++) {
if (graph[i][j]==INFINITY&&graph[j][i]!=INFINITY) {
graph[i][j] = graph[j][i];
}
}
}
Dijkstra(s);
System.out.print(Spnum[d]+" ");
System.out.print(values[d]);
System.out.println("");
StringBuilder st = new StringBuilder(s+"");
st.append(" "+d);
while (Pathmatirx[d]!=0) {
st.insert(1, " "+Pathmatirx[d]);
d = Pathmatirx[d];
}
System.out.print(st.toString());
} public static void Dijkstra(int v0) {
int v,w,k = 0,min;
values = new int[MAXVEX];
int[] res = new int[MAXVEX]; //判断是否已经保存最短路径
for (int i = 0; i < MAXVEX; i++) {
ShortPathTable[i] = graph[v0][i];
if (i!=v0) {
values[i] = nums[i]+nums[v0];
}
}
Arrays.fill(Spnum, 1);
res[v0] = 1;//v0->v0 v0最短路径就是自己
values[v0] = nums[v0];
for (int i = 0; i < MAXVEX; i++) {
if (i == v0) {
continue;
}
min = INFINITY;
for (int j = 0; j < MAXVEX; j++) {
if (res[j]==0&&ShortPathTable[j]<min) { //最短路径还未找出 且权值最小
k = j; //保存离i节点最近的节点
min = ShortPathTable[j];
} }
//这个循环结束后 暂时的最短路径保存下来 但是只有离i节点最近的节点加入了res
res[k] = 1; for (int j = 0; j < MAXVEX; j++) {
//如果节点没有加入res 且现有的路径比之前找到过的小 就更新
//若节点未联通 graph[k][j]和ShorPath[j]都是65535
if (res[j] == 0&&(min+graph[k][j])<ShortPathTable[j]) {
ShortPathTable[j] = min+graph[k][j];
values[j] = values[k]+nums[j];
Spnum[j] = Spnum[k];
Pathmatirx[j] = k;
}else if ((res[j] == 0&&(min+graph[k][j])==ShortPathTable[j])) {
Spnum[j] +=Spnum[k];
if (values[j]<values[k]+nums[j]) {
values[j]=values[k]+nums[j];
Pathmatirx[j] = k; //这个要放在里面 若是又更好的路径 就更换前置节点
}
} } } }
}
#include <cstdio>
#include <algorithm>
using namespace std;
int const MAX = ;
int const INF = 0x3fffffff;
int graph[MAX][MAX], val[MAX], dis[MAX], totval[MAX], pathnum[MAX], path[MAX];
bool vis[MAX];
int n, m, s, d; void Dijkstra(int v0)
{
for (int i = ; i < n; i++)
{
dis[i] = graph[v0][i];
totval[i] = val[i] + val[v0];
pathnum[i] = ;
vis[i] = false;
path[i] = v0;
}
vis[v0] = true;
totval[v0] = val[v0];
for (int i = ; i < n; i++)
{
if (i == v0)
{
continue;
}
int min = INF;
int k = ;
for (int j = ; j < n; j++)
{
if (vis[j] == false && min > dis[j])
{
min = dis[j];
k = j;
}
}
vis[k] = true;
for (int i = ; i < n; i++)
{
if (vis[i] == false)
{
if (min + graph[k][i] < dis[i])
{
dis[i] = min + graph[k][i];
pathnum[i] = pathnum[k];
totval[i] = totval[k] + val[i];
path[i] = k;
}
else if (min + graph[k][i] == dis[i])
{
pathnum[i] += pathnum[k];
if (totval[i] < totval[k] + val[i])
{
totval[i] = totval[k] + val[i];
path[i] = k; }
}
}
}
}
} int main()
{
scanf("%d %d %d %d", &n, &m, &s, &d);
for (int i = ; i < n; i++)
{
scanf("%d", &val[i]);
}
for (int i = ; i < n; i++)
{
for (int j = ; j < n; j++)
{
graph[i][j] = INF;
}
graph[i][i] = ;
}
for (int i = ; i < m; i++)
{
int t1, t2, t3;
scanf("%d %d %d", &t1, &t2, &t3);
graph[t1][t2] = t3;
graph[t2][t1] = t3;
}
Dijkstra(s);
printf("%d %d\n", pathnum[d], totval[d]);
int t = d;
int index = ;
int res[MAX];
while (t != s)
{
res[index++] = t;
t = path[t];
}
res[index++] = s;
for (int i = index - ; i > ; i--) {
printf("%d ", res[i]);
}
printf("%d\n", res[]); }
以前一直想参加PAT,看上去那么的高大上,虽然每届只有千把人参加,但是现在看看这个比赛对于java的不友好,还是算了吧.
Dijkstra算法_最短路径_L2-001. 紧急救援的更多相关文章
- Dijkstra算法_北京地铁换乘_android实现-附带源码.apk
Dijkstra算法_北京地铁换乘_android实现 android 2.2+ 源码下载 apk下载 直接上图片 如下: Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计 ...
- dijkstra算法计算最短路径和并输出最短路径
void dijisitela(int d, int m1) { ], book[], path[], u, v, min; l = ; ; i < n1; i++) { dis[i] = w[ ...
- Dijkstra算法求最短路径(java)(转)
原文链接:Dijkstra算法求最短路径(java) 任务描述:在一个无向图中,获取起始节点到所有其他节点的最短路径描述 Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到 ...
- 『算法设计_伪代码』贪心算法_最短路径Dijkstra算法
Dijkstra算法实际上是一个贪婪算法(Greedy algorithm).因为该算法总是试图优先访问每一步循环中距离起始点最近的下一个结点.Dijkstra算法的过程如下图所示. 初始化 给定图中 ...
- 《算法导论》读书笔记之图论算法—Dijkstra 算法求最短路径
自从打ACM以来也算是用Dijkstra算法来求最短路径了好久,现在就写一篇博客来介绍一下这个算法吧 :) Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到其他所有节点的 ...
- AI贪吃蛇前瞻——基于Dijkstra算法的最短路径问题
在贪吃蛇流程结构优化之后,我又不满足于亲自操刀控制这条蠢蠢的蛇,干脆就让它升级成AI,我来看程序自己玩,哈哈. 一.Dijkstra算法原理 作为一种广为人知的单源最短路径算法,Dijkstra用于求 ...
- _DataStructure_C_Impl:Dijkstra算法求最短路径
// _DataStructure_C_Impl:Dijkstra #include<stdio.h> #include<stdlib.h> #include<strin ...
- 通俗易懂理解——dijkstra算法求最短路径
迪杰斯特拉(Dijkstra)算法是典型最短路径算法,用于计算一个节点到其他节点的最短路径.它的主要特点是以起始点为中心向外层层扩展(广度优先搜索思想),直到扩展到终点为止 ###基本思想 通过Dij ...
- poj 1125 Stockbroker Grapevine dijkstra算法实现最短路径
点击打开链接 Stockbroker Grapevine Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 23760 Ac ...
随机推荐
- Could not autowire. No beans of 'TbAssetsMapper' type found. less... (Ctrl+F1) Inspection info:Checks autowiring problems in a bean class.
报错:Could not autowire. No beans of 'TbAssetsMapper' type found. less... (Ctrl+F1) Inspection info:Ch ...
- 旧文备份:安装cygwin及在console下输入和显示中文
1.下载Cygwin.exe文件,双击安装,首先在"Choose A Download Source"的时候选择"Download Without Installing& ...
- JS笔试汇总
//console.log(a[b]); var a={}; var b={key:'b'}; var c={key:'c'}; a[b] = 456; a[c] = 123; console.log ...
- 线段树的应用xx中学模拟lites
跟昨天那个自己写的,没有按照模板来的一看风格就不相类似,今天模拟赛的时候就是用的我的那个自己YY的代码,才拿了10分.个人认为关键的问题应该在于对于数据的处理太过繁琐了,所以回来之后,就拿了大佬的程序 ...
- Atlas实现mysql主从分离
可以接受失败,无法接受放弃!加油! 一.介绍Atlas及架构图 Atlas源代码用C语言编写,它对于Web Server相当于是DB,相对于DB相当于是Client,如果把Atlas的逻辑放到Web ...
- uplift model学习笔记
一.解决的问题: 通常的 Propensity Model 和 Response Model 只是给目标用户打了个分,并没有确保模型的结果可以使得活动的提升最大化:它没有告诉市场营销人员,哪个用户最有 ...
- jquery 配合 ajax 完成 在线编辑 你值得拥有
思路分析: 将 table中的表格 改变成为 input表格框获得值 ajax配合修改 删除 <?php use yii\helpers\Url; $web = Url::base(); ?&g ...
- perl语言入门总结-第3章-列表与数组
1-列表list指的是标题的有序集合, 而数组(array)则是存储列表的变量. 更精确地说,列表指的是数据,而数组指的是变量. 访问数组中的元素 ] = "yabba"; ] = ...
- python使用网易邮箱发邮件
# -*- coding: UTF-8 -*- import smtplib from email.mime.text import MIMEText import email.mime.multip ...
- 笔记-python-多线程-深入-1
笔记-python-多线程-深入-1 1. 线程池 1.1. 线程池:控制同时存在的线程数量 threading没有线程池,只能自己控制线程数量. 基本有两种方式: 每间隔一段时间创建 ...