B - Frogger
题目链接
 湖中有n块石头,编号从1到n,有两只青蛙,Bob在1号石头上,Alice在2号石头上,Bob想去看望Alice,但由于水很脏,他想避免游泳,于是跳着去找她。但是Alice的石头超出了他的跳跃范围。因此,Bob使用其他石头作为中间站,通过一系列的小跳跃到达她。两块石头之间的青蛙距离被定义为两块石头之间所有可能路径上的最小必要跳跃距离,某条路径的必要跳跃距离即这条路径中单次跳跃的最远跳跃距离。你的工作是计算Alice和Bob石头之间的青蛙距离。
 Input
 多实例输入
 先输入一个整数n表示石头数量,当n等于0时结束。
 接下来2-n+1行依次给出编号为1到n的石头的坐标xi , yi。
 2 <= n <= 200
 0 <= xi , yi <= 1000
 Output
 先输出"Scenario #x", x代表样例序号。
 接下来一行输出"Frog Distance = y", y代表你得到的答案。
 每个样例后输出一个空行。
 (ps:wa有可能是精度问题,g++不对可以用c++尝试,都不对就是代码问题)
 Sample Input
 2
 0 0
 3 4
3
 17 4
 19 4
 18 5
0
 Sample Output
 Scenario #1
 Frog Distance = 5.000
Scenario #2
 Frog Distance = 1.414
 **题意:**湖中有n块石头,编号从1到n,有两只青蛙,Bob在1号石头上,Alice在2号石头上,Bob要跳着去找Alice;
 两块石头之间的青蛙距离被定义为两块石头之间所有可能路径上的最小必要跳跃距离,某条路径的必要跳跃距离即这条路径中单次跳跃的最远跳跃距离。你的工作是计算Alice和Bob石头之间的青蛙距离。
 解题思路:最短路;
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<math.h>
#include<string.h>
using namespace std;
struct node
{
    double x,y;
}m[500];
double n[1002][1002];
int main()
{
    int t;
    int f=0;
    while(scanf("%d",&t)&&t)
    {
        for(int i=1;i<=t;i++)
        {
            scanf("%lf%lf",&m[i].x,&m[i].y);
        }
        for(int i=1;i<=t;i++)
        {
            for(int j=1;j<=t;j++)
            {
                n[i][j]=n[j][i]=sqrt((m[i].x-m[j].x)*(m[i].x-m[j].x)+(m[i].y-m[j].y)*(m[i].y-m[j].y));//求两个石头之间的距离 记录
            }
        }
        for(int k=1;k<=t;k++)//三层for 最短路  
        {
            for(int i=1;i<=t;i++)
            {
                for(int j=1;j<=t;j++)
                {
                    if(n[i][j]>max(n[i][k],n[k][j]))
                        n[i][j]=max(n[i][k],n[k][j]);
                }
            }
        }
        f++;
        printf("Scenario #%d\n",f);
        printf("Frog Distance = %.3lf\n",n[1][2]);
        cout<<endl;
    }
    return 0;
}
查看9道真题和解析
小天才公司福利 1160人发布