题目大意:
有N个城市,编号1-N
有R条路,每条路(单向)的起点为Si,终点为Di,长度为Li,如果要走这条路需要花Ti的钱
现在你只有K元钱,求在不超支的前提下,从1走到N需要的最短距离

这里总是希望路程尽可能的短,那么利用dijkstra的方法来解决问题,总是先扩展距离近的点,这样能更快的找到终点的最短路

节点的扩展满足二维的情况,只要路程和费用两个限制条件中的其中一个满足情况那么当前节点便要扩展

用cost[i],dis[i]记录在i节点所能达到的最优状态,只有某个情况left>cost[v] && d<dis[i] 那么两维情况都满足条件,就可以更新cost[],dis[]

但是这里要注意的是 dis[n]并不一定是最终答案,因为可能路程最短并不一定花费最少,那么就不会去更新这两个数组,我们只要把第一个带n的从

优先队列中跳出的点的长度作为答案即可,因为是优先队列,所以先弹出的n的点,一定是距离最短的

 #include <cstdio>
#include <cstring>
#include <iostream>
#include <queue>
using namespace std;
#define N 10010
#define MAXN 200010
#define ll long long
const int INF = 0x3f3f3f3f; int k,n,m;
int dis[N] , cost[N];
int first[N] , kk; struct Edge{
int x , y , next , d , c;
Edge(int x= , int y= , int next= , int d= , int c=):x(x),y(y),next(next),d(d),c(c){}
}e[N<<]; struct City{
int id , d , money;
City(int id , int d= , int money=):id(id),d(d),money(money){}
bool operator<(const City &m) const {
if(d == m.d) return money<m.money;
else return d>m.d;
}
}; priority_queue<City> q; void add_edge(int x,int y,int d,int c)
{
e[kk] = Edge(x,y,first[x],d,c);
first[x]=kk++;
} int dijkstra()
{
while(!q.empty()) q.pop();
memset(dis , 0x3f , sizeof(dis));
memset(cost , - , sizeof(cost));
q.push(City( , , k));
dis[] = , cost[] = k;
while(!q.empty())
{
City u = q.top();
q.pop();
if(u.id == n) return u.d;
if(u.d>dis[u.id] && u.money<cost[u.id]) continue;
for(int i = first[u.id] ; ~i ; i=e[i].next){
int v = e[i].y;
if(u.money-e[i].c>= && (u.money-e[i].c>cost[v] || u.d+e[i].d<dis[v])){
int left = u.money-e[i].c;
int distance = u.d+e[i].d;
q.push(City(v,distance,left));
if(left>cost[v] && distance<dis[v]){
cost[v] = left;
dis[v] = distance;
}
}
}
}
return INF;
} int main()
{
// freopen("a.in" , "r" , stdin);
while(~scanf("%d%d%d", &k , &n , &m))
{
kk=;
memset(first , - , sizeof(first));
for(int i= ; i<m ; i++){
int x,y,d,c;
scanf("%d%d%d%d" , &x , &y , &d , &c);
add_edge(x , y , d , c);
}
int ans = dijkstra();
if(ans == INF) puts("-1");
else printf("%d\n" , ans);
}
return ;
}

POJ 1724 二维费用最短路的更多相关文章

  1. HDU 3496 (二维费用的01背包) Watch The Movie

    多多想看N个动画片,她对这些动画片有不同喜欢程度,而且播放时长也不同 她的舅舅只能给她买其中M个(不多不少恰好M个),问在限定时间内观看动画片,她能得到的最大价值是多少 如果她不能在限定时间内看完买回 ...

  2. HDU 2159 二维费用背包问题

    一个关于打怪升级的算法问题.. 题意:一个人在玩游戏老是要打怪升级,他愤怒了,现在,还差n经验升级,还有m的耐心度(为零就删游戏不玩了..),有m种怪,有一个最大的杀怪数s(杀超过m只也会删游戏的.. ...

  3. hdu2159二维费用背包

    题目连接 背包九讲----二维费用背包 问题 二维费用的背包问题是指:对于每件物品,具有两种不同的费用:选择这件物品必须同时付出这两种代价:对于每种代价都有一个可付出的最大值(背包容量).问怎样选择物 ...

  4. 2159 ACM 杭电 杀怪 二维费用的背包+完全背包问题

    题意:已知经验值,保留的忍耐度,怪的种数和最多的杀怪数.求进入下一级的最优方案. 思路:用二维费用的背包+完全背包问题 (顺序循环)方法求解 什么是二维费用的背包问题? 问题: 二维费用的背包问题是指 ...

  5. 洛谷 P1507 NASA的食物计划 【二维费用背包】 || 【DFS】

    题目链接:https://www.luogu.org/problemnew/show/P1507 题目背景 NASA(美国航空航天局)因为航天飞机的隔热瓦等其他安全技术问题一直大伤脑筋,因此在各方压力 ...

  6. Regionals 2014 >> Asia - Taichung 7003 - A Balance Game on Trees 树形DP + 二维费用背包

    https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...

  7. 动态规划:HDU3496-Watch The Movie(二维费用的背包问题)

    Watch The Movie Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others) ...

  8. 动态规划:HDU2159-FATE(二维费用的背包问题)

    FATE Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submi ...

  9. 洛谷 P1509 找啊找啊找GF(复习二维费用背包)

    传送门 题目背景 "找啊找啊找GF,找到一个好GF,吃顿饭啊拉拉手,你是我的好GF.再见." "诶,别再见啊..." 七夕...七夕...七夕这个日子,对于sq ...

随机推荐

  1. Spark SQL catalyst概述和SQL Parser的具体实现

    之前已经对spark core做了较为深入的解读,在如今SQL大行其道的背景下,spark中的SQL不仅在离线batch处理中使用广泛,structured streamming的实现也严重依赖spa ...

  2. P3742 umi的函数

    题目背景 umi 找到了一个神秘的函数 f. 题目描述 这个函数接受两个字符串 s1,s2.这些字符串只能由小写字母组成,并且具有相同的长度.这个函数的输出是另一个长度与 s1,s2 相同的字符串 g ...

  3. 用NPOI从Excel到DataTable

    NPOI功能强大,不用装Excel,就可以操作表格中数据----Excel.Sheet------>DataTable private IWorkbook workbook = null; pr ...

  4. .net服务端生成二维码

    mvc4   net4.0 1.引用附件的DLL文件 2.两个函数即可 #region 生成二维码 public ActionResult getQrCode() { using (var ms = ...

  5. python+selenium(环境的安装)

    前言:网上的资料层次不齐,且资料也不全,容易误导新手,所以笔者愿意把你的知识免费分享给大家,笔者用的版本为:python3 此时可能新手就会问了,为什么不用python2呢,因为道理很简单,人要往前走 ...

  6. 微信小程序开发系列一:微信小程序的申请和开发环境的搭建

    我最近也刚刚开始微信小程序的开发,想把我自学的一些心得写出来分享给大家. 这是第一篇,从零开始学习微信小程序开发.主要是小程序的注册和开发环境的搭建. 首先我们要在下列网址申请一个属于自己的微信小程序 ...

  7. Unity查找物体的四大主流方法及区别

    GameObject.Find()优点: 使用简单方便不会因为重名而报错,同时查找的是自上而下的第一个物体缺点 不能查找被隐藏的物体,否则出现“空引用异常”,这是很多新人在查找出现空引用bug的原因. ...

  8. python 网络编程篇

    基础模拟通话网络程序: #客户端 import socket client = socket.socket() client.connect(('localhost',6969)) client.se ...

  9. react 的CDN 连接

    以下内容均摘抄自react官网 React 和 ReactDOM 都可以在 CDN 上获得. <script crossorigin src="https://unpkg.com/re ...

  10. Robot Framework(十四) 扩展RobotFramework框架——创建测试库

    4.1创建测试库 Robot Framework的实际测试功能由测试库提供.有许多现有的库,其中一些甚至与核心框架捆绑在一起,但仍然经常需要创建新的库.这个任务并不复杂,因为正如本章所示,Robot ...