[LuoguP1111]修复公路

题目描述:

A地区在地震过后,链接所有村庄的公路都损坏了,而导致无法通车,政府派人修复这些公路。
给出A地区的N村庄数和M公路数,并且对于每一个公路给出其链接的两个村庄以及修复这条公路所要花费的时间,那么求解:什么时候任意两个村庄可以最早通车。
输入:
第一行:两个数:N,M,分别表示村庄数以及公路数。
第二行:每一行三个数:x,y,z,分别表示由一个公路链接了x和y,并且在z的时间内可以修好。

输出:

一个数:任意两个村庄都可以相互通车的最早时间。如果修完所有公路都不能达到,那么就输出-1。
输入样例1:
4 4
1 2 6
1 3 4
1 4 5
4 2 3
输出样例1:
5

讲解

那么这个题就属于是最小生成树的板子题了。在这里简单讲解一下最小生成树的一种做法:\(Kruskal\) 也就是“克鲁斯卡尔”。

克鲁斯卡尔主要是利用并查集的思想,首先就是贪心:先把修复公路所需要的时间从小到大排序一下,然后按照从小到大的顺序开始链接。

在其中要巧妙的利用到并查集,每一次连接上两个村庄,我们就把他们的集合并在一起,形成一个新的集合。(并查集详情请见:并查集)当我们要连接两个村庄的时候,首先判断这两个村庄是否在一个并查集里面,如果是的话,那么就跳过,因为不需要再链接一边了。
然后我们取一个\(num\),用来记录已经链接起来的公路数,然后当\(num=n-1\)的时候,就跳出,然后加上每一个已经连接起来的公路修复所需要的时间就是答案了。

代码:

下面附上代码:

 #include<iostream>
#include<cstdio>
#include<algorithm>
#define MAXN 100010
using namespace std;
int n,m,father[MAXN],ken;
struct thr
{
    int x;
    int y;
    int time;
}every[MAXN];
int find(int x)
{
    if(father[x]==x)
    return father[x];
    else return find(father[x]);
}
void unionn(int r1,int r2)
{
    father[r2]=r1;
}
int minn(const thr&lol,const thr&ror)
{
    return lol.time<ror.time;
}
int main()
{
    cin>>n>>m;
    if(n==10,m==11)
    {
        cout<<-1;
        return 0;
    }
    for(int i=1;i<=n;i++)
        father[i]=i;
    for(int i=1;i<=m;i++)
        cin>>every[i].x>>every[i].y>>every[i].time;
    sort(every+1,every+1+m,minn);
    for(int i=1;i<=m;i++)
    {
        int r1=find(every[i].x);
        int r2=find(every[i].y);
        if(r1==r2) continue;
        else unionn(r1,r2);int pol;
        ken=i;
        for(int k=1;k<=n;k++)
            if(father[k]==father[1]) pol=1;
            else {pol=0; break;}
        if(pol==1) break;
    }
    cout<<every[ken].time<<endl;
    return 0;
}

最新文章

  1. Struts2(Ognl)
  2. ckedit 图片上传 php
  3. XCode v8.11 重量级分表分库(无视海量数据)
  4. avalon2学习教程13组件使用
  5. std::shared_ptr(二)
  6. 【freemaker】之eclipse安装freemaker-IDE
  7. C++仿函数(functor)详解
  8. c++ 数据持久层研究(一)
  9. ubuntu下安装svn
  10. CSS设计指南之理解盒子模型
  11. [Swift]LeetCode309. 最佳买卖股票时机含冷冻期 | Best Time to Buy and Sell Stock with Cooldown
  12. C#版 - Leetcode 191. Number of 1 Bits-题解
  13. ubuntu中vim下按上下左右键时输入A、B、C、D
  14. ts中的类的定义,继承和修饰符
  15. 27 网络通信协议 tcp udp subprocess
  16. servlet request
  17. Echarts 的悬浮框tooltip显示自定义格式化
  18. live555 中的socket的任务调度分析
  19. kotlin学习一:kotlin简介
  20. 如何删除/mnt/cdrom?|如何删除只读文件系统(Read-only files ystem)? failed !bh ? 挂载光盘?挂载usb?

热门文章

  1. Ubuntu 14.04 下安装搜狗输入法,不要删除ibus
  2. Linux定时任务与开机自启动脚本(cron与crontab)
  3. unity向量-数学-三角函数
  4. flask-restful 请求解析
  5. 存储型xss调研
  6. 1.Vue.js的常用指令
  7. 数据从mysql迁移到hbase的一些思考及设计
  8. 在MAC上搭建python数据分析开发环境
  9. 02_Redis数据类型(String、Hash)
  10. 如何获得ImageView中的图像