洛谷4568: 飞行路线

题意:

  • 给定一张无向图有\(n\)个点编号为\(0\)到\(n-1\)。共有\(m\)条边,每条边有一个边权。
  • 可以选择\(k\)条边将边权改变为\(0\),给定起点和终点,问从起点到终点的路径的最小边权和为多少。

输入描述:

  • 第一行输入三个整数\(n,m,k\),分别表示点数,边数,\(k\)。
  • 第二行输入两个整数\(s,t\)表示起点和终点。
  • 接下来有\(m\)行,每行输入\(x,y,z\)表示从\(x\)到\(y\)有边权为\(z\)的边。
  • 数据范围
    • \(n\leq10^4,m\leq5*10^4,k\leq10,z\leq10^3\)

输出描述:

  • 输出一个整数表示答案。

思路:

  • 分层图模板题。
  • 以样例为例:

  • 建完图后跑最短路即可
  • 建完分层图后边数和点数的计算问题:
    • 点数: 每一层点有\(n\)个点,一共建立\(k\)层图,所以总点数为\(n*k\)。
    • 边数: 每一层图有\(m\)条边,那么总共有\(k*m\)条边,相邻两层相互连边有\(k-1\)个中间层,所以总边数为\(k*m\)条边。无向图开两倍即可。
  • 同时防止毒瘤数据,每层终点连边,解决在\(k\)还没用完时就到达终点的情况。
  • 所以这时候点数\(+n\),边数\(+m\)
  • \(Hint\): 这里的无向图双向连边是指一层内部双向连边,而层与层之间只能单向连边。

代码:

#include<bits/stdc++.h>
#define PII pair<int, int>
using namespace std; const int maxn = (1e4+10) * 11;
const int maxm = 1e6 + 10 + 5e4 + 10; int n, m, k, s, t; int head[maxn], ver[maxm<<1], nex[maxm<<1], edge[maxm<<1], tot;
inline void add_edge(int x, int y, int z){
ver[++tot] = y; edge[tot] = z;
nex[tot] = head[x]; head[x] = tot;
} int dist[maxn];
bool v[maxn];
void dijkstra()
{
memset(dist, 0x3f, sizeof(dist));
dist[s] = 0;
priority_queue<PII, vector<PII>, greater<PII> > q;
q.push({0, s});
while(q.size())
{
int x = q.top().second; q.pop();
if(v[x]) continue;
v[x] = 1;
for(int i = head[x]; i; i = nex[i])
{
int y = ver[i], z = edge[i];
if(dist[y] > dist[x] + z)
{
dist[y] = dist[x] + z;
q.push({dist[y], y});
}
} }
} int main()
{
scanf("%d%d%d%d%d", &n, &m, &k, &s, &t);
s++; t++;
for(int i = 1, x, y, z; i <= m; i++)
{
scanf("%d%d%d", &x, &y, &z); x++, y++;
add_edge(x, y, z); add_edge(y, x, z);
for(int j = 1; j <= k; j++)
{
//相互两层之间连边
add_edge(x+(j-1)*n, y+j*n, 0);
add_edge(y+(j-1)*n, x+j*n, 0);
//一层中内部连边
add_edge(x+j*n, y+j*n, z);
add_edge(y+j*n, x+j*n, z);
}
} //防止毒瘤数据, k次机会还没用完就到了终点
for(int i = 1; i <= k; i++)
add_edge(t+(i-1)*n, t+i*n, 0); //每层之间的终点连边
dijkstra();
cout << dist[t+k*n] << endl;
return 0;
}

luogu_4568: 飞行路线的更多相关文章

  1. BZOJ2763[JLOI2011]飞行路线 [分层图最短路]

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 2523  Solved: 946[Submit][Statu ...

  2. 分层图+最短路算法 BZOJ 2763: [JLOI2011]飞行路线

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec  Memory Limit: 128 MB Description Alice和Bob现在要乘飞机旅行,他们选择了一家相 ...

  3. BZOJ 2763: [JLOI2011]飞行路线 最短路

    2763: [JLOI2011]飞行路线 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  4. poj 2763: [JLOI2011]飞行路线(spfa分层图最短路)

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 2156 Solved: 818 [Submit][Statu ...

  5. Bzoj 2763: [JLOI2011]飞行路线 dijkstra,堆,最短路,分层图

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1728  Solved: 649[Submit][Statu ...

  6. Bzoj 2763: [JLOI2011]飞行路线 拆点,分层图,最短路,SPFA

    2763: [JLOI2011]飞行路线 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1694  Solved: 635[Submit][Statu ...

  7. [JLOI 2011]飞行路线&[USACO 09FEB]Revamping Trails

    Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n-1,一共有m种航线,每种航线连接两个城市,并 ...

  8. [JLOI2011]飞行路线 不同的算法,不同的悲伤

    题目 :BZOJ2763 洛谷P4568 [JLOI2011]飞行路线 一道最短路的题目,想想写个题解也不错(好久没写题解了_(:з」∠)_) 然后这道题中心思路是dijikstra处理最短路,所以没 ...

  9. 洛谷 P4568 [JLOI2011]飞行路线 解题报告

    P4568 [JLOI2011]飞行路线 题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在\(n\)个城市设有业务,设这些城市分别标记为0到\(n−1\ ...

随机推荐

  1. 『正睿OI 2019SC Day3』

    容斥原理 容斥原理指的是一种排重,补漏的计算思想,形式化的来说,我们有如下公式: \[\left | \bigcup_{i=1}^nS_i \right |=\sum_{i}|S_i|-\sum_{i ...

  2. SQL server中常用sql语句

    --循环执行插入10000条数据 declare @ID intbeginset @ID=1 while @ID<=10000begininsert into table_name values ...

  3. 利用Properties属性集结合类加载器读取配置文件

    配置文件test.properties a=123 测试类Demo1.java public class Demo1 { public static void main(String[] args) ...

  4. springboot如何读取配置文件中的参数(例如:application-consts.properties) 又结合maven读取配置文件的顺序

    1.启动项目后,会读取pom.xml中的配置文件,例如现在读取的是本地配置 2.找到对应的配置文件  会读取uri地址下的配置.注:如果为springboot启动无需加config项目的名称,应该本身 ...

  5. window界面自动化

    一.windows带界面的自动化1.AutoIt AutoIt3官方下载地址:https://www.autoitscript.com/files/autoit3/autoit-v3-setup.ex ...

  6. 【C++编程基础】(1)—— 函数原型声明、函数模板、引用、const 常引用、const 常量指针

    一.函数原型声明: 1.函数声明告诉编译器函数的名称,和如何调用函数(返回类型和参数):函数定义提供了函数的实际主体. 2.强制性的:在C++中,如果函数调用的位置在函数定义之前,则要求在函数调用之前 ...

  7. Redis学习总结整理

    基本操作 设值 set KEY VALUE 获值 get KEY 设置过期时间(单位:s) set KEY VALUE ex SECONDS 设置过期时间(单位:s) exprire KEY SECO ...

  8. 微博api接口登陆,获取信息,分享微博

    import json from datetime import datetime import MySQLdb import requests from flask import Flask, re ...

  9. springboot 单元测试 指定启动类

    问题 在做单元测试时,写了一个工具类,用于注入spring的上下文. public class AppBeanUtil implements ApplicationContextAware { pri ...

  10. Httpd服务入门知识-Httpd服务常见配置案例之配置持久连接

    Httpd服务入门知识-Httpd服务常见配置案例之配置持久连接 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.查看默认的持久连接时间 [root@node101.yinzhe ...