题目

Description

已知每个点的加油站的油价单价(即点权),每条路的长度(边权)。

有q个询问,每个询问包括起点s、终点e和油箱容量c。

问从起点走到终点的最小花费。如果不可达输出impossible,否则输出最小的旅途费用。

Solution

第一想法想到拆点,每个点拆成 0~c 那么多个点,妥妥TLE。

后来看题解想到可以进行一个最短路DP,用一个三元组 (x,y,z) 表示当前在点 x,花了 y 元,油量为 z,把这个压进优先队列,每次取出堆中 y 最少的点进行更新即可。

这里还有个奇技淫巧般的优化,就是每次取出堆顶时,不用从当前直接把油箱加满,只加 1 单位的油量就够了,这是为什么呢?其实跟飞扬的小鸟一样,为了优化时间,我们可以让 dp 从自己向自己转移,也就是说,这次只加 1 单位,下次取出时还是只加 1 单位,那么迟早会遍历所有的 n*c 状态。

哦对还要注意一点,vis 数组不要在 if 里面更新,要在取到它的时候再变为 1,不然早早变为 1 有可能让能令其更优的状态无法转移过来。

Code

// By YoungNeal
#include<queue>
#include<cstdio>
#include<cstring>
#include<iostream>
using namespace std;

int T;
int c,s,e;
int n,m,cnt;
];
];
][];
][];

struct Edge{
    int nxt,to,dis;
}edge[];

void add(int x,int y,int z){
    edge[++cnt].to=y;
    edge[cnt].nxt=head[x];
    edge[cnt].dis=z;
    head[x]=cnt;
}

struct Node{
    int now,dis,oil;
    Node(,,):now(now),dis(dis),oil(oil){}
    friend bool operator<(Node a,Node b){
        return a.dis>b.dis;
    }
};

priority_queue<Node> pq;

void dij(){
    while(pq.size()) pq.pop();
    pq.push(Node(s,,));
    while(pq.size()){
        Node p=pq.top();pq.pop();
        int o=p.oil,u=p.now;
        if(vis[u][o]) continue;
        vis[u][o]=;
        if(u==e){
            printf("%d\n",p.dis);
            return;
        }
        <=c&&!vis[u][o+]&&dis[u][o+]>dis[u][o]+val[u]){
            dis[u][o+]=p.dis+val[u];
            pq.push(Node(u,p.dis+val[u],o+));
        }
        for(int i=head[u];i;i=edge[i].nxt){
            int to=edge[i].to;
            int w=edge[i].dis;
            if(o>=w&&!vis[to][o-w]&&dis[to][o-w]>p.dis){
                dis[to][o-w]=p.dis;
                pq.push(Node(to,p.dis,o-w));
            }
        }
    }
    printf("impossible\n");
}

signed main(){
    scanf("%d%d",&n,&m);
    ;i<=n;i++) scanf("%d",&val[i]);
    ;i<=m;i++){
        scanf("%d%d%d",&x,&y,&z);
        add(x+,y+,z);
        add(y+,x+,z);
    }
    scanf("%d",&T);
    while(T--){
        scanf("%d%d%d",&c,&s,&e);
        s++,e++;
        memset(vis,,sizeof vis);
        memset(dis,0x3f,sizeof dis);
        dis[s][]=;
        dij();
    }
    ;
}

[POJ 3635] Full Tank?的更多相关文章

  1. POJ 3635 - Full Tank? - [最短路变形][手写二叉堆优化Dijkstra][配对堆优化Dijkstra]

    题目链接:http://poj.org/problem?id=3635 题意题解等均参考:POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]. 一些口胡: ...

  2. POJ 3635 Full Tank? 【分层图/最短路dp】

    任意门:http://poj.org/problem?id=3635 Full Tank? Time Limit: 1000MS   Memory Limit: 65536K Total Submis ...

  3. POJ 3635 - Full Tank? - [最短路变形][优先队列优化Dijkstra]

    题目链接:http://poj.org/problem?id=3635 Description After going through the receipts from your car trip ...

  4. poj 3635 Full Tank? ( bfs+dp思想 )

    Full Tank? Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 5857   Accepted: 1920 Descri ...

  5. poj 3635 Full Tank? ( 图上dp )

    题意: 已知每一个点的加油站的油价单位价格(即点权).每条路的长度(边权). 有q个询问.每一个询问包含起点s.终点e和油箱容量. 问从起点走到终点的最小花费.假设不可达输出impossible,否则 ...

  6. 【POJ 3635】 Full Tank

    [题目链接] http://poj.org/problem?id=3635 [算法] 优先队列BFS 实现类似于堆优化dijkstra [代码] #include <algorithm> ...

  7. Full Tank? POJ - 3635 (bfs | 最短路)

    After going through the receipts from your car trip through Europe this summer, you realised that th ...

  8. poj 3635/hdu 1676 Full Tank? 车辆加油+最短路

    http://acm.hdu.edu.cn/showproblem.php?pid=1676 给出一张图,n<=1000,m<=10000. 有一辆车想从图的一个地方到达另外一个地方,每个 ...

  9. poj 3635(bfs+优先队列)

    题目链接:http://poj.org/problem?id=3635 思路:本题主要运用的还是贪心思想,由于要求st->ed的最小花费,那么每经过一个城市,能不加油就尽量不加油,用dp[i][ ...

随机推荐

  1. 浅谈JavaScript位操作符

    因为ECMAscript中所有数值都是以IEEE-75464格式存储,所以才会诞生了位操作符的概念. 位操作符作用于最基本的层次上,因为数值按位存储,所以位操作符的作用也就是操作数值的位.不过位操作符 ...

  2. iOS 开发之内存泄漏问题

    关于内存泄漏问题,一般情况下就是控制器或者视图没有正常的释放引起的,我们通常可以通过dealloc方法来检查一个控制器或者视图是否释放. 对于一个控制器或者视图没有释放,其实也就是还有强引用引用着这个 ...

  3. 【java学习笔记】线程

    1.线程的定义 ①继承Thread类,将执行的任务逻辑放到run方法中,调用start方法来开启线程 public class ThreadDemo { public static void main ...

  4. Visual Studio Code搭建python开发环境

    开发Python的环境有很多,原来已经在vs2013上面搭建好python的开发环境了,但是vs2013每次启动都占太多内存(太强大了吧),这下出了vs code,既轻量又酷炫,正好拿来试一试开发py ...

  5. 1.2 PCI总线的信号定义

    PCI总线是一条共享总线,在一条PCI总线上可以挂接多个PCI设备.这些PCI设备通过一系列信号与PCI总线相连,这些信号由地址/数据信号.控制信号.仲裁信号.中断信号等多种信号组成. PCI总线是一 ...

  6. eclipse生成【带有外部jar包】的java可执行jar包

    之前有写过一篇使用eclipse生成java可执行jar包,但是最近的一次使用中无论如何都不成功,当双击执行打成的jar时,弹出如下错误: could not find the main class: ...

  7. JSP自定义标签配置

    JSP自定义标签配置 JSP自定义标签 <taglib>         <taglib-uri>/WEB-INF/you.tld</taglib-uri>     ...

  8. 机器学习相关的tutorial

    1. MRF 马尔可夫随机场 http://homepages.inf.ed.ac.uk/rbf/CVonline/LOCAL_COPIES/AV0809/ORCHARD/ 从MRF,讲到Gibbs分 ...

  9. SDP(11):MongoDB-Engine功能实现

    根据上篇关于MongoDB-Engine的功能设计方案,我们将在这篇讨论里进行功能实现和测试.下面是具体的功能实现代码:基本上是直接调用Mongo-scala的对应函数,需要注意的是java类型和sc ...

  10. 洛谷P4219 [BJOI2014]大融合(LCT,Splay)

    LCT维护子树信息的思路总结与其它问题详见我的LCT总结 思路分析 动态连边,LCT题目跑不了了.然而这题又有点奇特的地方. 我们分析一下,查询操作就是要让我们求出砍断这条边后,x和y各自子树大小的乘 ...