• 【洛谷 1108】低价购买


    题目背景

    《爱与愁的故事第三弹·shopping》第一章。

    题目描述

    中山路店山店海,成了购物狂爱与愁大神的“不归之路”。中山路上有n(n<=100)家店,每家店的坐标均在-10000~10000之间。其中的m家店之间有通路。若有通路,则表示可以从一家店走到另一家店,通路的距离为两点间的直线距离。现在爱与愁大神要找出从一家店到另一家店之间的最短距离。你能帮爱与愁大神算出吗?

    输入格式

    共n+m+3行:

    第1行:整数n

    第2行~第n+1行:每行两个整数x和y,描述了一家店的坐标

    第n+2行:整数m

    第n+3行~第n+m+2行:每行描述一条通路,由两个整数i和j组成,表示第i家店和第j家店之间有通路。

    第n+m+3行:两个整数s和t,分别表示原点和目标店

    输出格式

    仅一行:一个实数(保留两位小数),表示从s到t的最短路径长度。

    输入输出样例

    输入 #1
    5
    0 0
    2 0
    2 2
    0 2
    3 1
    5
    1 2
    1 3
    1 4
    2 5
    3 5
    1 5
    输出 #1
    3.41

    说明/提示

    100%数据:n<=100,m<=1000

    题解:最短路(各类方法皆可用,而我选择了我最 i 的floyd)

    #include<cstdio>
    #include<iostream>
    #include<cmath>
    #include<cstring>
    #include<cstdlib>
    #include<algorithm>
    #include<queue>
    using namespace std;
    const int oo=0x3f3f3f3f;
    const int N=102;
    double f[N][N];
    int n,m,x[N],y[N],ss,tt,a,b;
    double js(int a1,int a2,int b1,int b2)
        { return (double)sqrt((a1-a2)*(a1-a2)+((b1-b2))*((b1-b2))); }
    
    int main(){
        memset(f,0x7f,sizeof(f));
        scanf("%d",&n);
        for(int i=1;i<=n;i++)
            scanf("%d %d",&x[i],&y[i]);
        scanf("%d",&m);
        for(int i=1;i<=m;i++){
            scanf("%d %d",&a,&b);
            f[a][b]=f[b][a]=js(x[a],x[b],y[a],y[b]);
        }
        for(int k=1;k<=n;k++)
            for(int i=1;i<=n;i++)
                for(int j=1;j<=n;j++)
                    if(i!=j && i!=k && k!=j)
                       f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
        scanf("%d %d",&ss,&tt);
        printf("%.2f
    ",f[ss][tt]);
        return 0;
    }
  • 相关阅读:
    Eclipse快捷键大全
    Quartz任务调度快速入门
    Spring整合logback日志
    Java实现二维码的生成与解析
    跨域问题及解决方案
    SpringBoot项目直接在linux下运行
    SpringBoot拦截器中使用RedisTemplate
    Codeforces Round #345 (Div. 1) C. Table Compression dp+并查集
    HDU 4489 The King’s Ups and Downs dp
    HDU 4747 Mex 递推/线段树
  • 原文地址:https://www.cnblogs.com/wuhu-JJJ/p/11809034.html
Copyright © 2020-2023  润新知