P1730 最小密度路径

题面

题目描述

给出一张有 \(N\) 个点 \(M\) 条边的加权有向无环图,接下来有 \(Q\) 个询问,每个询问包括 \(2\) 个节点 \(X\) 和 \(Y\) ,要求算出从 \(X\) 到 \(Y\) 的一条路径,使得密度最小(密度的定义为,路径上边的权值和除以边的数量)。

输入输出格式

输入格式:

第一行包括 \(2\) 个整数 \(N\) 和 \(M\) 。

以下 \(M\) 行,每行三个数字 \(A\) 、 \(B\) 、 \(W\) ,表示从 \(A\) 到 \(B\) 有一条权值为 \(W\) 的有向边。

再下一行有一个整数 \(Q\) 。

以下 \(Q\) 行,每行一个询问 \(X\) 和 \(Y\) ,如题意所诉。

输出格式:

对于每个询问输出一行,表示该询问的最小密度路径的密度(保留 \(3\) 位小数),如果不存在这么一条路径输出“OMG!”(不含引号)。

输入输出样例

输入样例:

3 3
1 3 5
2 1 6
2 3 6
2
1 3
2 3

输出样例:

5.000
5.500

说明

\(1 \leq N \leq 50, 1 \leq M \leq 1000, 1 \leq W \leq 100000, 1 \leq Q \leq 100000\)

思路

我们来做一点 \(NOIP D1T2\) 难度的图论题吧......来,洛谷 P4467。 --digger_sun

下午孙教练突然叫我们过去做了一些图论题,太毒瘤了 \(qwq\) 。特别是这道题,我没有做出来,因为完全没和动态规划联系到一起。最后则是 logeadd 的代码救了我。

进入正题。显然普通的松弛操作在这里不适用了,考虑使用记录状态的动态规划。定义 \(dis[i][j][k]\) 为从 \(i\) 点出发到达 \(j\) 点,中途恰好经过了 \(k\) 条边的最短距离。那么假设在从点 \(s\) 出发的一次最短路中,现在的状态是已经经过了 \(k\) 条边的点 \(u\) 和它的最短路径,对于一条边 \((u,v,d)\) 我们就可以这样松弛:

\[f[s][v][k+1]=min(f[s][v][k+1],f[u][v][k]+d)
\]

最后统计答案时枚举经过的边数,就可以完成啦。

AC代码

#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int> PII;
const int INF=0x3f3f3f3f;
int n,m,q,dis[55][55][1005];
int cnt,top[55],to[1005],len[1005],nex[1005];
int read()
{
int re=0;
char ch=getchar();
while(!isdigit(ch)) ch=getchar();
while(isdigit(ch)) re=(re<<3)+(re<<1)+ch-'0',ch=getchar();
return re;
}
void SPFA(int s)
{
dis[s][s][0]=0;
queue<PII>Q;
Q.push(make_pair(s,0));
while(!Q.empty())
{
int now=Q.front().first,edge=Q.front().second;Q.pop();
for(int i=top[now];i;i=nex[i])
if(dis[s][to[i]][edge+1]>dis[s][now][edge]+len[i])
{
dis[s][to[i]][edge+1]=dis[s][now][edge]+len[i];
Q.push(make_pair(to[i],edge+1));
}
}
return ;
}
int main()
{
n=read(),m=read();
memset(dis,0x3f,sizeof dis);
for(int i=0;i<m;i++)
{
int x=read(),y=read(),z=read();
to[++cnt]=y,len[cnt]=z,nex[cnt]=top[x],top[x]=cnt;
}
q=read();
while(q--)
{
int s=read(),t=read();
SPFA(s);
double ans=INF;
for(int i=1;i<=m;i++) if(dis[s][t][i]!=INF) ans=min(ans,double(dis[s][t][i])/double(i));
if(ans!=INF) printf("%.3f\n",ans);
else puts("OMG!");
}
return 0;
}

Luogu P1730 最小密度路径(最短路径+dp)的更多相关文章

  1. [Luogu 1730]最小密度路径

    Description 给出一张有N个点M条边的加权有向无环图,接下来有Q个询问,每个询问包括2个节点X和Y,要求算出从X到Y的一条路径,使得密度最小(密度的定义为,路径上边的权值和除以边的数量). ...

  2. [洛谷P1730] 最小密度路径

    类型:Floyd 传送门:>Here< 题意:定义一条路径密度 = 该路径长度 / 边数.给出一张$DAG$,现有$Q$次询问,每次给出$X,Y$,问$X,Y$的最小密度路径($N \le ...

  3. 洛谷P1730 最小密度路径(floyd)

    题意 题目链接 Sol zz floyd. 很显然的一个dp方程\(f[i][j][k][l]\)表示从\(i\)到\(j\)经过了\(k\)条边的最小权值 可以证明最优路径的长度一定\(\leqsl ...

  4. 洛谷P1730最小密度路径

    题目传送门; 首先理解题目,究其本质就是一个最短路问题,而且数据范围贼水,用floyd完全没问题,但是题目有变化,要求出路径边权值与边数之比,这里就可以考虑在把floyd中的二维数组变为三维,f[ i ...

  5. 【洛谷P1730】最小密度路径

    题目大意:给定一个 N 个点,M 条边的有向图,现有 Q 个询问,每次询问 X 到 Y 的最小密度路径是多少.最小密度路径的定义是路径长度除以路径边数. 题解:利用矩阵乘法,可以预处理出从 X 到 Y ...

  6. Luogu 2764 最小路径覆盖问题 / Libre 6002 「网络流 24 题」最小路径覆盖 (网络流,最大流)

    Luogu 2764 最小路径覆盖问题 / Libre 6002 「网络流 24 题」最小路径覆盖 (网络流,最大流) Description 给定有向图G=(V,E).设P是G的一个简单路(顶点不相 ...

  7. luogu P2764 最小路径覆盖问题

    题目描述 给定有向图G=(V,E).设P 是G 的一个简单路(顶点不相交)的集合.如果V 中每个顶点恰好在P 的一条路上,则称P是G 的一个路径覆盖.P 中路径可以从V 的任何一个顶点开始,长度也是任 ...

  8. Luogu 1613 跑路(最短路径,倍增)

    Luogu 1613 跑路(最短路径,倍增) Description 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是 ...

  9. Leetcode 931. Minimum falling path sum 最小下降路径和(动态规划)

    Leetcode 931. Minimum falling path sum 最小下降路径和(动态规划) 题目描述 已知一个正方形二维数组A,我们想找到一条最小下降路径的和 所谓下降路径是指,从一行到 ...

随机推荐

  1. 爬虫所需要的文档和自动化文本driver下载地址,以及制作词云的文档,api等

    Scrapy1.7.3文档 webdriver文档 webdriver下载地址 Chrom各版本下载地址 词云1.5文档 selenium中文文档 vue数据可视化文档 element开发组件 其他好 ...

  2. 工作记录--WPF自定义控件,实现一个可设置编辑模式的TextBox

    原文:工作记录--WPF自定义控件,实现一个可设置编辑模式的TextBox 1. 背景 因为最近在使用wpf开发桌面端应用,在查看页面需要把TextBox和Combox等控件设置为只读的.原本是个很简 ...

  3. Python对象和类

    Python 里的所有数据都是以对象形式存在的,对象是类的实例. 定义类(class) 使用class来定义一个类. 比如,定义一个cat类,如下: class Cat(): def __init__ ...

  4. IDEA将代码推送至远程GitHub仓库

    1 在项目根路径下添加.gitignore文件 2 创建本地git仓库 3 git add操作 快捷键 ctrl+alt+a 4 git commit操作 快捷键ctrl+k 5 git push操作 ...

  5. LUOGU P2580 于是他错误的点名开始了(trie树)

    传送门 解题思路 trie树模板

  6. windows下VisualSVN Server搭建

    转自:https://www.cnblogs.com/shuilangyizu/p/10365604.html 使用 VisualSVN Server来实现主要的 SVN功能则要比使用原始的 SVN和 ...

  7. 杂项-VOD:VOD(视频点播)

    ylbtech-杂项-VOD:VOD(视频点播) 视频点播是二十世纪90年代在国外发展起来的,英文称为“Video on Demand”,所以也称为“VOD”.顾名思义,就是根据观众的要求播放节目的视 ...

  8. momentjs 使用总结

    一.安装 cnpm install moment 二.引入 var moment = require('moment') 三.使用 let today = moment().format('YYYY- ...

  9. Spring注解驱动(上)

    记录常用的spring注解 1.@Configuration 和 @Bean spring中可以使用xml 的方式进行配置, 也可以使用 @ Configuration 来指定一个类为配置类, 并使用 ...

  10. Python学习day43-数据库(多表关系)

    figure:last-child { margin-bottom: 0.5rem; } #write ol, #write ul { position: relative; } img { max- ...