7-10 公路村村通(并查集kruskal)

7-10 公路村村通(并查集kruskal)最小生成树题目链接现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本。输入格式:输入数据包括城镇数目正整数N(≤1000)和候选道路数目M(≤3N);随后的M行对应M条道路,每行给出3个正整数,分别是该条道路直接连通的两个城镇的编号以及该道路改建的预算成本。为简单起见,城镇从1到N编号。输出格式:输出村村通需要的最低成本。如果输入数据不足以保证畅通,则输出−1,表示需要建设更多公路。输入样例:6 151 2 51 3 3

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

最小生成树

题目链接

现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本。

输入格式:
输入数据包括城镇数目正整数N(≤1000)和候选道路数目M(≤3N);随后的M行对应M条道路,每行给出3个正整数,分别是该条道路直接连通的两个城镇的编号以及该道路改建的预算成本。为简单起见,城镇从1到N编号。

输出格式:
输出村村通需要的最低成本。如果输入数据不足以保证畅通,则输出−1,表示需要建设更多公路。

输入样例:

6 15
1 2 5
1 3 3
1 4 7
1 5 4
1 6 2
2 3 4
2 4 6
2 5 2
2 6 6
3 4 6
3 5 1
3 6 1
4 5 10
4 6 8
5 6 3

输出样例:

12

C++代码

#include<bits/stdc++.h>
#define x first
#define y second
using namespace std;
typedef long long ll;
const int N = 1e3 + 10;
const int M = 3 * N;
const int INF = 0x3f3f3f3f;
typedef pair<int,int> PII;
struct Edge{ 
   
    int u,v,w;
    bool operator<(const Edge &edge)const{ 
   
        return w < edge.w;
    }
}edge[M];
int fa[N],n,m;
void init(){ 
   
    for(int i = 0;i < n;i ++)fa[i] = i;
}
int Find(int x){ 
   
    return fa[x] = (x == fa[x] ? x : Find(fa[x]));	//压缩路径并查集
}
int main(){ 
   
    cin>>n>>m;
    init();
    int x,y,w;
    for(int i = 0;i < m;i ++){ 
   
        cin>>x>>y>>w;
        edge[i].u = x;
        edge[i].v = y;
        edge[i].w = w;
    }
    sort(edge,edge + m);
    int res = 0,cnt = 0;
    for(int i = 0;i < m;i ++){ 
   
        int X = Find(edge[i].u),Y = Find(edge[i].v);
        if(X != Y){ 
   
            fa[X] = Y;
            res += edge[i].w;
            cnt ++;
        }
    }
    if(cnt != n - 1)cout<< -1;
    else cout<<res;
    return 0;
}

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

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

(0)
上一篇 2022年8月8日 下午12:00
下一篇 2022年8月8日 下午12:00


相关推荐

  • delphi xe datasnap 服务器显示客户端,Delphi xe datasnap[通俗易懂]

    delphi xe datasnap 服务器显示客户端,Delphi xe datasnap[通俗易懂]我想从客户端向服务端提交多个OleVariant内容.最初我想这样这实现functionSaveData(aDataArr:arrayofOleVariant;aTableArr:arrayofstring;aKeyArr:arrayofstring;varaErrorStr:string):Boolean;这样经测试不行,DATASNAP参数不能为数组.现在我用TJSONObje…

    2022年7月18日
    15
  • 大学生简单个人静态HTML网页设计作品 DIV布局个人介绍网页模板代码 DW学生个人网站制作成品下载 HTML5期末大作业 (1)「建议收藏」

    大学生简单个人静态HTML网页设计作品 DIV布局个人介绍网页模板代码 DW学生个人网站制作成品下载 HTML5期末大作业 (1)「建议收藏」HTML5期末大作业:动漫电影主题——电影动漫言叶之庭(4页)带音乐HTML+CSS+JavaScript期末作业HTML代码学生网页课程设计期末作业下载web网页设计制作成品大学生毕设网页设计源码HTML1.临近期末,你还在为HTML网页设计结课作业,老师的作业要求感到头大?HTML网页作业无从下手?网页要求的总数量太多?2.没有合适的模板?等等一系列问题。你想要解决的问题,在这篇博文中基本都能满足你的需求~3.原始HTML+CSS+JS页面设计,web大学生网页设计作业

    2025年9月24日
    16
  • 简单说一下寄存器寻址

    简单说一下寄存器寻址对于初学的朋友来说 寄存器寻址的几个常见的方式 理解起来还是比较麻烦的 现在尽量给大家说明白一点 所谓寻址 就是要找存放某个东西的位置 以下用日常生活中的情形来打比方 虽然不是很精准 但还是能方便理解 隐含寻址 就是说存放东西的位置是相对固定的 东西 a 永远存在 A 处 东西 b 永远存在 B 处 以此类推 所以不用你费劲找 做事要用到某个东西时 会自动去固定的地方取 立即寻址 就是在让你做事的时候 同时把你要用的东西也给你 也是不用你忙活着去找 直接寻址 就是告诉你储物柜的

    2026年3月19日
    1
  • layer弹出层详解

    layer弹出层详解前言:学习layer弹出框,之前项目是用bootstrap模态框,后来改用layer弹出框,在文章的后面,我会分享项目的一些代码(我自己写的)。layer至今仍作为layui的代表作,她的受众广泛并非偶然,而是这五年多的坚持,不断完善和维护、不断建设和提升社区服务,使得猿们纷纷自发传播,乃至于成为今天的Layui最强劲的源动力。目前,layer已成为国内最多人使用的web弹层组件,GitHub…

    2022年7月13日
    27
  • 智普WHILE网络刷博器爬虫「建议收藏」

    智普WHILE网络刷博器爬虫

    2022年3月3日
    155
  • Kimi智能助手:深度思考的AI对话伙伴

    Kimi智能助手:深度思考的AI对话伙伴

    2026年3月12日
    3

发表回复

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

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