人们的Live Meeting系列 (floyd)

人们的Live Meeting系列 (floyd)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

人活着系列之开会


Time Limit: 1000MS Memory limit: 65536K

题目描写叙述

人活着假设是为了事业。从打工的到老板的,个个都在拼搏,奋斗了多年最终有了非凡成就。有了一笔丰富的钱財。反过来说。人若赚取了全世界又有什么益处呢?生不带来。死了你还能带去吗?金钱能买保险,但不能买生命,金钱能买药品,但不能买健康,人生在世,还是虚空呀!

在苍茫的大海上。有非常多的小岛。每一个人都在自己的小岛上。

又到了开会的时候了,鹏哥通过飞信告知了每一个人,然后大家就開始往鹏哥所在的主岛走,问谁先到达主岛。

有几点注意事项:

  1. 主岛一定除了鹏哥之外没有不论什么人。

  2. 并不是全部的小岛上都有人,有的小岛为空。

  3. 例子保证一定有人会先到达主岛。

  4. 小岛上最多仅仅有一个人。

  5. 每一个人往主岛走的速度同样

  6. 每一个小岛都有一条或多条路与别的小岛相连,可能和自己有一条路相连

  7. 至少有一个小岛和主岛相连。保证全部的人都能够到达主岛

  8. 为了节约时间,每一个人都走最短的路径

  9. 两个岛之间或许不仅仅有一条路相连。

  10. 每一个小岛都被标记为字母,大写字母代表这个小岛有人,小写字母代表这个小岛没有人。Z代表鹏哥所在主岛的位置

  11. Aa表示两个不同的牧场。A a 8代表的是A岛到a岛的距离是A岛上是有人的,a岛上是没有人的。

输入

第一行 :,代表着大海上一共同拥有N条连接小岛的路,(1<= N<=10000)

接下来N行,每一行有两个字母和一个整数len,代表着两个岛的标记是否存在人。以及这两个岛之间的距离。(1<=len<=1000)

输出

最先到达主岛的那个人所在的岛的字母以及他走过的路径长度。

演示样例输入

6
A e 6
e Z 8
B c 3
c d 2
D A 12
d Z 3

演示样例输出

B 8 

题目不难,仅仅需将字母转化为矩阵的坐标。大写和小写字母一共52个,弗洛伊德肯定过
11条注意。非常重要

#include <iostream>
#include <cstdio>
#include <cstring>
#include <math.h>
#include <cstdlib>
#include <algorithm>
const int INF = 1e6;
using namespace std;
int dis[110][110],sum;

void init()
{
    for(int i = 1;i <= 52;i ++)
    {
        for(int j = 1;j <= 52;j++)
        {
            if(i==j) dis[i][j] = 0;
            else
                dis[i][j] = INF;
        }

    }
}
int GET(char a)
{
    if(a >= 'A'&&a <= 'Z')
    return a-'A'+1;
    else
    return a-'a'+27;
}
void Flyed()
{
    sum = INF;
    for(int k = 1;k<53;k++)
    {
        for(int i = 1;i<53;i++)
        {
            for(int j = 1;j<53;j++)
            {
                if(dis[i][j] > dis[i][k]+dis[k][j])
                dis[i][j] = dis[i][k]+dis[k][j];
            }
        }
    }
}
int main()
{
    int n,c;
    char a[5],b[5];
    scanf("%d",&n);
    getchar();
    init();
    for(int i = 1;i <= n;i ++)
    {
        scanf("%s%s%d",a,b,&c);

       int x = GET(a[0]);
       int y = GET(b[0]);

        if(dis[x][y] > c)
        {
            dis[x][y] = dis[y][x] = c;
        }
    }
    Flyed();

   int st;
    for(int i = 1;i<26;i++)
    {
        if(sum > dis[i][26])
        {
            sum = dis[i][26];
            st = i;
        }
    }
    st--;
    printf("%c %d\n",st+'A',sum);
    return 0;
}

版权声明:本文博主原创文章,博客,未经同意不得转载。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/116750.html原文链接:https://javaforall.net

(0)
上一篇 2022年1月16日 上午10:00
下一篇 2022年1月16日 上午11:00


相关推荐

  • CNN结构化剪枝综述[项目源码]

    CNN结构化剪枝综述[项目源码]

    2026年3月14日
    1
  • 深入理解设计模式-外观模式(门面模式)

    深入理解设计模式-外观模式(门面模式)外观模式也称为门面模式 是一种通过为多个复杂的子系统提供一个一致的接口 而使这些子系统更加容易被访问的模式 该模式对外有一个统一接口 外部应用程序不用关心内部子系统的具体的细节 这样会大大降低应用程序的复杂度 提高了程序的可维护性 外观 Facade 模式是 迪米特法则 的典型应用

    2026年3月18日
    2
  • Windows命令之route命令「建议收藏」

    Windows命令之route命令「建议收藏」route命令用于显示和操作IP路由表。要实现两个不同的子网之间的通信,需要一台连接两个网络的路由器,或者同时位于两个网络的网关来实现。windows环境下route命令常用于多网卡终端,默认路由指向连接访问互联网的网卡,静态路由指向内网网卡。

    2022年7月18日
    23
  • 复合主键与联合主键[通俗易懂]

    复合主键与联合主键[通俗易懂]一、复合主键 所谓的复合主键就是指你表的主键含有一个以上的字段组成,不使用无业务含义的自增id作为主键。比如 createtabletest(namevarchar(19),idnumber,valuevarchar(10),primarykey(name,id))上面的name和id字段组合起来就是你

    2022年6月17日
    39
  • pycharm连接远程服务器并调试代码

    pycharm连接远程服务器并调试代码最近申请了学校的远程服务器资源 在加上自己的渣渣笔记本确实有点菜 于是寻思着把计算环境部署到 Linux 服务器上 通过 pycharm 连接远程服务器并调试代码 搞起来 文章目录 pycharm 连接远程服务器设置远程连接配置 1 配置连接 2 配置映射关系 3 配置忽略路径 可选 4 添加远程 Pythoninterp 连接远程服务器设置远程连接配置打开配置面板在配置面板中可以为你当前的连接起一个名称 这个名称是用于给你区分你连接的是哪台服务器的 下面依次有三个选项卡 connecti

    2026年2月20日
    3
  • ubuntu 安装wine qq教程[通俗易懂]

    ubuntu 安装wine qq教程[通俗易懂]ubuntu安装wineqq教程小编装了真机,传文件是在麻烦,所以自己百度了好多办法,终于安装上了qq1.下载好这个版本的qq (各大网站都有,自己百度就可以了)  2.然后在ubuntu ,用解压软件 归档管理器打开并提取。3.然后逐次安装三个包。安装方法:可以用ubuntu自带的软件安装器安装(16.04好像不能用,我也不知道为啥,还有一种方法,用命令安装 在你提…

    2025年9月5日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号