1459 迷宫游戏

基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题 收藏 关注

你来到一个迷宫前。该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间,你就可以得到这个分数。还有若干双向道路连结这些房间,你沿着这些道路从一个房间走到另外一个房间需要一些时间。游戏规定了你的起点和终点房间,你首要目标是从起点尽快到达终点,在满足首要目标的前提下,使得你的得分总和尽可能大。现在问题来了,给定房间、道路、分数、起点和终点等全部信息,你能计算在尽快离开迷宫的前提下,你的最大得分是多少么?

Input

第一行4个整数n (<=500), m, start, end。n表示房间的个数,房间编号从0到(n - 1),m表示道路数,任意两个房间之间最多只有一条道路,start和end表示起点和终点房间的编号。

第二行包含n个空格分隔的正整数(不超过600),表示进入每个房间你的得分。

再接下来m行,每行3个空格分隔的整数x, y, z (0< z <=200)表示道路,表示从房间x到房间y(双向)的道路,注意,最多只有一条道路连结两个房间, 你需要的时间为z。

输入保证从start到end至少有一条路径。

Output

一行,两个空格分隔的整数,第一个表示你最少需要的时间,第二个表示你在最少时间前提下可以获得的最大得分。

Input示例

3 2 0 2

1 2 3

0 1 10

1 2 11

Output示例

21 6

标准的最短路, dijkstra算法变一下, 多重判断就好了

实现代码:

#include<bits/stdc++.h>

using namespace std;

const int maxn = 1000 + 131;
const int INF = 0x7fffffff; int Va[maxn]; /// 房间价值 struct Edge { /// 图的边结构
int from, to, Cost, Value;
Edge(int f, int t, int c, int v) :\
from(f), to(t), Cost(c), Value(v) {}
}; struct Get {
int time, value;
}; struct HeapNode { /// 优先队列的节点
int t, d, u;
HeapNode(int _t, int _d, int _u) :\
t(_t), d(_d), u(_u) {} bool operator < (const HeapNode& rhs) const {
if (t == rhs.t) return d < rhs.d;
return t > rhs.t;
}
}; struct Dijkstra {
int n, m; /// 点数和边数
vector<Edge> edges; /// 边列表
vector<int> G[maxn]; /// 每个节点出发的编号(从 0 开始)
bool done[maxn]; /// 是否已永久标号
Get d[maxn]; /// s 到各个节点的距离, 价值
int p[maxn]; /// 最短路中的上一条边。 void init(int n) {
this -> n = n;
for (int i = 0; i < n; ++i) G[i].clear();
edges.clear();
} void AddEdges(int from, int to, int dist) {
edges.push_back(Edge(from, to, dist, Va[to]));
m = edges.size();
G[from].push_back(m-1);
} void dijkstra(int s) {
priority_queue<HeapNode> Q;
for(int i = 0; i <n; ++i) d[i].time = INF, d[i].value = -1;
d[s].time = 0, d[s].value = Va[s];
memset(done, 0, sizeof(done));
Q.push(HeapNode(0,Va[s],s));
while(!Q.empty()) {
HeapNode x = Q.top(); Q.pop();
int u = x.u;
if(done[u]) continue;
done[u] = true;
for(int i = 0; i < G[u].size(); ++i) {
Edge& e = edges[G[u][i]];
if(d[e.to].time > d[u].time + e.Cost) { ///时间多就更新
d[e.to].time = d[u].time + e.Cost;
d[e.to].value = d[u].value + e.Value;
p[e.to] = G[u][i];
Q.push(HeapNode(d[e.to].time, d[e.to].value, e.to));
} else if(d[e.to].time == d[u].time + e.Cost && d[e.to].value < d[u].value + e.Value) {
/// 时间相同, 价值大的更新。
d[e.to].value = d[u].value + e.Value;
p[e.to] = G[u][i];
Q.push(HeapNode(d[e.to].time, d[e.to].value, e.to));
}
}
}
}
}Dj; int main() {
int m, n, st, ed, fr, to, co;
while(cin >> n >> m >> st >> ed) {
Dj.init(n);
for(int i = 0; i < n; ++i) {
cin >> Va[i];
} for(int i = 0; i < m; ++i) {
cin >> fr >> to >> co;
Dj.AddEdges(fr, to, co);
Dj.AddEdges(to, fr, co);
}
Dj.dijkstra(st);
cout << Dj.d[ed].time << ' ' << Dj.d[ed].value << endl;
}
}

51nod--1459 迷宫游戏 (dijkstra)的更多相关文章

  1. 51nod 1459 迷宫游戏 dijkstra模板

    链接:迷宫游戏 问题 - 51Nod  http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1459 1459 迷宫游戏  基准 ...

  2. 51nod 1459 迷宫游戏(dij)

    题目链接:51nod 1459 迷宫游戏 dij裸题. #include<cstdio> #include<cstring> #include<algorithm> ...

  3. 51nod 1459 迷宫游戏【最短路拓展】

    1459 迷宫游戏 基准时间限制:1 秒 空间限制:131072 KB   你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间,你就可以得到这个分数.还有若干双向道路连 ...

  4. 51nod 1459 迷宫游戏 (最短路径—Dijkstra算法)

    题目链接 中文题,迪杰斯特拉最短路径算法模板题. #include<stdio.h> #include<string.h> #define INF 0x3f3f3f3f ],v ...

  5. 51 NOd 1459 迷宫游戏 (最短路径)

    1459 迷宫游戏  基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间, ...

  6. 51Nod 1459:迷宫游戏(最短路)

    1459 迷宫游戏  基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间, ...

  7. 51nod1459 迷宫游戏

    1459 迷宫游戏 基准时间限制:1 秒 空间限制:131072 KB 分值: 0 难度:基础题  收藏  关注 你来到一个迷宫前.该迷宫由若干个房间组成,每个房间都有一个得分,第一次进入这个房间,你 ...

  8. c语言迷宫游戏的实现

    // // main.c // 迷宫游戏代码实现 // #include <stdio.h> #define ROW 6 //宏定义行 #define COL 6 //宏定义列 /** * ...

  9. 用webgl打造自己的3D迷宫游戏

    用webgl打造自己的3D迷宫游戏 2016/09/19 · JavaScript · WebGL 原文出处: AlloyTeam    背景:前段时间自己居然迷路了,有感而发就想到写一个可以让人迷路 ...

随机推荐

  1. python matplotlib 库学习

    基本使用 import matplotlib.pyplot as plt import numpy as np x = np.linspace(-1,1,50) y = 2*x+1 plt.figur ...

  2. 服务器部署全程记录(centos6.5)

    1.安装nginx 上传安装包:put E:\yz_index\installPackage\nginx-1.14.0.tar.gz 解压:tar zxvf nginx-1.14.0.tar.gz 切 ...

  3. Oracle SQL*Plus命令

    登录数据库: 方式(1)当我们刚安装Oracle数据库时,登录账户时可以使用win+r 输入sqlplus,进入sqlplus命令窗口,然后输入用户名和密码,这里输入密码时不会有回显 方式(2)使用w ...

  4. 大规模数据导入和导出(oracle)

    请期待... http://www.cnblogs.com/xwdreamer/archive/2012/06/08/2541678.html Oracle sqlldr的用法 (这个最完整) htt ...

  5. mybatis的两个核心对象SqlSessionFactory和SqlSession对象

    mybatis的两个核心对象SqlSessionFactory和SqlSession对象 参见:https://www.cnblogs.com/wxdestiny/p/9743686.html

  6. redis踩坑记录

    1. 关于redis启动后的warnning: WARNING you have Transparent Huge Pages (THP) support enabled in your kernel ...

  7. visual studio属性管理器

    位于 视图->其它窗口 项目配置属性,这个项目的属性别的项目也需要的时候可以把属性页复制到新项目. 以及配置单个项目的不同构建方案

  8. Hive通过mysql元数据表删除分区

    1 创建表 hive命令行操作 CREATE TABLE IF NOT EXISTS emp( name STRING, salary FLOAT, subordinates ARRAY<STR ...

  9. Flume配置Load balancing Sink Processor

    1 官网内容 2 找一个图来理解一目了然 3 详细配置 配置文件load_source_case.conf 配置数据入口 source到channel 配置了两个sink用来做负载均衡 #配置文件: ...

  10. Eclipse 自动生成 Ant的Build.xml 配置文件

    Eclipse 自动生成 Ant的Build.xml 配置文件,生成的方法很隐蔽 选择你要生成Build.xml文件的项目,右键. Export-> General -> Ant Buil ...