牛客-瘦了的牛牛去旅游(最短路的变形)

链接:https://ac.nowcoder.com/acm/contest/6164/D
来源:牛客网
 

题目描述

牛牛为了奖励自己减肥成功( 并没有),奖励自己去X市旅游,X市有N个地点,这些点之间有M条长度不同的边,他们组成了一张有向无环图,牛牛希望从一个点X到另外一个点Y走密度最小的一条路,所谓密度是指的从X到Y的总路程长度除以X到Y走过的边的数量。现在牛牛提出Q个询问,每次询问一对Xi,Yi,请你输出Xi到Yi密度最小的路径密度。

 

输入描述:


 

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

以下M行,每行三个数字u、v、w,表示从u点到v点有一条权值为w的有向边。

再下一行有一个整数Q。

以下Q行,每行一个询问X和Y,求X到Y的最小密度路径

输出描述:

对于每个询问输出一行,表示该询问的最小密度路径的密度(误差在1e-3范围内即可),如果不存在这么一条路径输出“OMG!”(不含引号)。

示例1

输入

 

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

输出

 

5.000
5.500

说明


 

1 ≤ N ≤ 50,1 ≤ M ≤ 1000,1 ≤ W ≤ 100000,1 ≤ Q ≤ 100000。

题解:因为考虑到n比较小,以及是个有向无环图(即任意两点之间的边不会超过n),所以使用floyd算法。

具体详见代码。

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
#include <map>
#include <set>
#include <stack>
#include <queue>
#include <vector>
#include <string>
#define cla(a, sum) memset(a, sum, sizeof(a))
#define rap(i, m, n) for(int i=m; i<=n; i++)
#define rep(i, m, n) for(int i=m; i>=n; i--)
#define bug printf("???\n")
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<ll, ll> P;
const int Inf = 0x3f3f3f3f;
const double eps = 1e-8;
const int maxn = 3e4;
template <typename T> void read(T &x){
    x = 0; int f = 1; char ch = getchar();
    while (!isdigit(ch)) {if (ch == '-') f = -1; ch = getchar();}
    while (isdigit(ch)) {x = x * 10 + ch - '0'; ch = getchar();}
    x *= f;
}
 
int n,m,q;
double d[55][55];
int f[55][55][55];//f[i][j][l]表示i到j之间有l条边的最短距离 
 
void init(){
    rap(i,0,n)
        rap(j,0,n){
            d[i][j]=1e9;
            rap(k,0,n)f[i][j][k]=1e9;
        }
}
 
int main()
{
    read(n);read(m);
    init();
    int u,v,w;
    while(m--){
        read(u);read(v);read(w);
        if(w<d[u][v]){//注意重边 
        	d[u][v]=w;
            f[u][v][1]=w;
		}
    }
    rap(l,2,n){//枚举边数 
        rap(k,1,n){//枚举中间点 
            rap(i,1,n){
                rap(j,1,n){
                    if(f[i][j][l]>f[i][k][l-1]+f[k][j][1]){
                        f[i][j][l]=f[i][k][l-1]+f[k][j][1];
                    }
                    //注意f[i][j][l]<1e9的更新条件。 
                    if(f[i][j][l]<1e9&&f[i][j][l]/(double)l<d[i][j]){
                        d[i][j]=f[i][j][l]/(double)l;
                    }
                }
            }
        }
    }
    read(q);
    while(q--){
        int x,y;
        read(x);read(y);
        if(d[x][y]>=1e9)printf("OMG!\n");
        else printf("%.3lf\n",d[x][y]);
    }
    return 0;
}

 

展开阅读全文

Python数据分析与挖掘

01-08
92讲视频课+16大项目实战+源码+¥800元课程礼包+讲师社群1V1答疑+社群闭门分享会=99元   为什么学习数据分析?       人工智能、大数据时代有什么技能是可以运用在各种行业的?数据分析就是。       从海量数据中获得别人看不见的信息,创业者可以通过数据分析来优化产品,营销人员可以通过数据分析改进营销策略,产品经理可以通过数据分析洞察用户习惯,金融从业者可以通过数据分析规避投资风险,程序员可以通过数据分析进一步挖掘出数据价值,它和编程一样,本质上也是一个工具,通过数据来对现实事物进行分析和识别的能力。不管你从事什么行业,掌握了数据分析能力,往往在其岗位上更有竞争力。    本课程共包含五大模块: 一、先导篇: 通过分析数据分析师的一天,让学员了解全面了解成为一个数据分析师的所有必修功法,对数据分析师不在迷惑。   二、基础篇: 围绕Python基础语法介绍、数据预处理、数据可视化以及数据分析与挖掘......这些核心技能模块展开,帮助你快速而全面的掌握和了解成为一个数据分析师的所有必修功法。   三、数据采集篇: 通过网络爬虫实战解决数据分析的必经之路:数据从何来的问题,讲解常见的爬虫套路并利用三大实战帮助学员扎实数据采集能力,避免没有数据可分析的尴尬。   四、分析工具篇: 讲解数据分析避不开的科学计算库Numpy、数据分析工具Pandas及常见可视化工具Matplotlib。   五、算法篇: 算法是数据分析的精华,课程精选10大算法,包括分类、聚类、预测3大类型,每个算法都从原理和案例两个角度学习,让你不仅能用起来,了解原理,还能知道为什么这么做。
©️2020 CSDN 皮肤主题: 大白 设计师: CSDN官方博客 返回首页
实付0元
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值