kruskal_并查集_代码模板 hdu1232

2023-12-03 14:09

本文主要是介绍kruskal_并查集_代码模板 hdu1232,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

kruskal代码模板

input

a _the number of verteices

b _the number of edges

v1_verteices

wi_the weight of each edge

#include<iostream>
#include<string>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<ctype.h>
#include<algorithm>
#include<map>
#include<vector>
#include<set>#define MAX 100005
#define MOD 1000003
#define inf 100000000
#define eps 1e-9
#define pi acos(-1.0)
#define LL long long 
#define I64 __int64
#define max(a, b) ((a) > (b) ? (a) : (b))
#define min(a, b) ((a) < (b) ? (a) : (b))using namespace std;struct edge {int v1, v2, w;
};int edge_num, vertex_num;
edge volume_e[30];
int father[30];int cmp (edge a, edge b) {return a.w < b.w;
}int find (int x) {int root = x;for (father[root] != root)root = father[root];return root;
}int main()
{freopen ("in.txt", "r", stdin);cin >> edge_num >> vertex_num;// the number of edge and vertex// v1, v2, weightfor (int i = 0;i < edge_num;i ++)scanf ("%d %d %d", &volume_e[i].v1, &volume_e[i].v2, &volume_e[i].w);// initialfor (int i = 1;i <= vertex_num;i ++) father[i] = i;sort (volume_e, volume_e+edge_num, cmp);int sum = 0;for (int i = 0; i < edge_num;i ++){int x = find (volume_e[i].v1);int y = find (volume_e[i].v2);if (x != y){sum += volume_e[i].w;father[x] = y;}}printf ("%d\n", sum);
}/*
5 5
1 2 2
2 3 3
1 4 1
3 4 2
4 5 4*/

HDU1232

#include<iostream>
#include<string>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<ctype.h>
#include<algorithm>
#include<map>
#include<vector>
#include<set>
using namespace std;int add;
int f[100010];
int n, m;int findset(int x)
{int set = x;while(f[set] != set){set = f[set];}return set;
}void merge(int a, int b)
{int x = findset(a);int y = findset(b);if(x != y)f[x] = y;
}int main()
{freopen("in.txt", "r", stdin);while(scanf("%d %d", &n, &m) == 2){add = 0;if(n == 0)break;else if(m == 0){add = n - 1;printf("%d\n", add);}else{for(int i = 1; i <= n; i++) f[i] = i;for(int i = 0; i < m; i++){int a, b;scanf("%d %d", &a, &b);merge(a, b);}for(int i = 1; i <= n; i++)if(f[i] == i)add++;add--;printf("%d\n", add);}//memset(f, 0, sizeof(f));}
}/*
4 2
1 3
4 3
3 3
1 2
1 3
2 3
5 2
1 2
3 5
999 0
0*/

这篇关于kruskal_并查集_代码模板 hdu1232的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/449715

相关文章

利用Python打造一个Excel记账模板

《利用Python打造一个Excel记账模板》这篇文章主要为大家详细介绍了如何使用Python打造一个超实用的Excel记账模板,可以帮助大家高效管理财务,迈向财富自由之路,感兴趣的小伙伴快跟随小编一... 目录设置预算百分比超支标红预警记账模板功能介绍基础记账预算管理可视化分析摸鱼时间理财法碎片时间利用财

如何在 Spring Boot 中实现 FreeMarker 模板

《如何在SpringBoot中实现FreeMarker模板》FreeMarker是一种功能强大、轻量级的模板引擎,用于在Java应用中生成动态文本输出(如HTML、XML、邮件内容等),本文... 目录什么是 FreeMarker 模板?在 Spring Boot 中实现 FreeMarker 模板1. 环

利用Python调试串口的示例代码

《利用Python调试串口的示例代码》在嵌入式开发、物联网设备调试过程中,串口通信是最基础的调试手段本文将带你用Python+ttkbootstrap打造一款高颜值、多功能的串口调试助手,需要的可以了... 目录概述:为什么需要专业的串口调试工具项目架构设计1.1 技术栈选型1.2 关键类说明1.3 线程模

Python Transformers库(NLP处理库)案例代码讲解

《PythonTransformers库(NLP处理库)案例代码讲解》本文介绍transformers库的全面讲解,包含基础知识、高级用法、案例代码及学习路径,内容经过组织,适合不同阶段的学习者,对... 目录一、基础知识1. Transformers 库简介2. 安装与环境配置3. 快速上手示例二、核心模

Java的栈与队列实现代码解析

《Java的栈与队列实现代码解析》栈是常见的线性数据结构,栈的特点是以先进后出的形式,后进先出,先进后出,分为栈底和栈顶,栈应用于内存的分配,表达式求值,存储临时的数据和方法的调用等,本文给大家介绍J... 目录栈的概念(Stack)栈的实现代码队列(Queue)模拟实现队列(双链表实现)循环队列(循环数组

IDEA自动生成注释模板的配置教程

《IDEA自动生成注释模板的配置教程》本文介绍了如何在IntelliJIDEA中配置类和方法的注释模板,包括自动生成项目名称、包名、日期和时间等内容,以及如何定制参数和返回值的注释格式,需要的朋友可以... 目录项目场景配置方法类注释模板定义类开头的注释步骤类注释效果方法注释模板定义方法开头的注释步骤方法注

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim