最小生成树,并查集的思想 nyoj1239
2024-10-19 23:42:18
#include<stdio.h>
#include<string.h>
#include<algorithm> using namespace std; int n,pre[10010],cnt;
struct node
{
int x,y;
int val;
} p[10010];
void init()
{
for(int i=0; i<10010; i++)
pre[i]=i;
}
int cmp(node s1,node s2)
{
return s1.val<s2.val;
}
int find(int x)
{
return x==pre[x]?x:find(pre[x]);
}
int join(int x,int y)
{
int fx=find(x);
int fy=find(y);
if(fx!=fy)
{
pre[fx]=fy;
return 1;
}
return 0;
}
int main()
{
int t;
scanf("%d",&t);
while(t--)
{
init();
cnt=0;
scanf("%d",&n);
for(int i=0; i<=n; i++)
{
for(int j=1; j<=n; j++)
{
scanf("%d",&p[cnt].val);
p[cnt].x=i,p[cnt++].y=j;
}
}
sort(p,p+cnt,cmp);
int sum=0;
for(int i=0; i<cnt; i++)
{
if(join(p[i].x,p[i].y))
sum+=p[i].val;
}
printf("%d\n",sum);
}
return 0;
}
最新文章
- Java FtpClient 实现文件上传服务
- 基于TCP和多线程实现无线鼠标键盘-GestureDetector
- DOS 下 mysql 导入.SQL
- Unity Shaders and Effets Cookbook
- 【BZOJ1010】【HNOI2008】玩具装箱
- Exception与相关
- No bean named &#39;transactionManager&#39; is defined
- Codeforces Round #341 (Div. 2) ABCDE
- Android学习路径(23)应用Fragment建立动态UI——Fragment之间的通信
- 微软Visual Studio &;quot;14&;quot; CTP 2 公布
- Ionic.Zip.dll文件压缩和解压
- 【IDEA】向IntelliJ IDEA创建的项目导入Jar包的两种方式
- List Set Map比较
- [Swift]动态变化顶部状态栏(statusBar)的颜色
- 带你了解CSRF和XSS(一)
- Word 2010 制作文档结构之图标自动编号设置
- sql判断某个字段是否为空
- 11.Spring——JDBC框架
- Activity设置背景透明之开发坑
- 【WPF】ScrollViewer无法滚动的问题
热门文章
- 使用 ftrace 调试 Linux 内核,第 2 部分
- WAMP本地环境升级php版本
- profile, bashrc, source, setup.*sh
- Codeforces Round #321 (Div. 2) E
- 航空售票系统设计分析(Markdownpad2图片服务器上传无法显示)
- 【Java TCP/IP Socket】深入剖析socket——TCP通信中由于底层队列填满而造成的死锁问题(含代码)
- gcc、arm-Linux-gcc和arm-elf-gcc的组成及区别
- decorate all function in all module
- 数据库系统学习(六)-SQL语言基本操作
- [转]java类 对象 和构造方法