最小生成树(无向图)

Kruskal

给所有边按从小到大排序 形成环则不选择(利用并查集)

P1546 最短网络   https://www.luogu.com.cn/problem/P1546

#include<iostream>
#include<cstdio>
#include<string>
#include<algorithm>
typedef long long ll;
using namespace std; struct Node {
int x, y, w;
friend bool operator < (const Node& a, const Node& b) {
return a.w < b.w;
}
}; Node a[];
int pre[]; int Find(int x) {
return pre[x] == x ? x : pre[x] = Find(pre[x]);
} int main() {
int n, k, cnt = ;
scanf("%d", &n);
for (int i = ; i < n; i++) {
pre[i] = i;
for(int j=;j<n;j++){
scanf("%d", &k);
if (j > i) { //矩阵只需判断一半
a[cnt].x = i;
a[cnt].y = j;
a[cnt++].w = k;
}
}
}
sort(a, a + cnt);
int ans = ;
int p = ;
for (int i = ; i <cnt; i++) {
if (Find(a[i].x) != Find(a[i].y)) {
ans += a[i].w;
pre[Find(a[i].x)] = a[i].y;
p++;
if (p == n - ) break;
}
}
printf("%d\n", ans);
return ;
}

HDU 1875 http://acm.hdu.edu.cn/showproblem.php?pid=1875

#include<iostream>
#include<cstdio>
#include<string>
#include<algorithm>
typedef long long ll;
using namespace std; struct Node {
int x, y;
double w;
friend bool operator < (const Node& a, const Node& b) {
return a.w < b.w;
}
}; Node a[]; //数组注意开大
int pre[];
double x[];
double y[]; int Find(int x) {
return pre[x] == x ? x : pre[x] = Find(pre[x]);
} double dis(double x1, double y1, double x2, double y2) {
return sqrt((x1 - x2) * (x1 - x2) + (y1 - y2) * (y1 - y2));
}
int main() {
int T,c;
scanf("%d", &T);
while (T--) {
int cnt = ;
scanf("%d", &c);
for (int i = ; i < c; i++) {
pre[i] = i;
scanf("%lf%lf", &x[i], &y[i]);
for (int j = ; j < i; j++) {
double dist = dis(x[i], y[i], x[j], y[j]);
if(dist>=10.0&&dist<=1000.0){
a[cnt].x = i;
a[cnt].y = j;
//printf("%d %d\n", a[cnt].x, a[cnt].y);
a[cnt++].w = dist;}
}
}
sort(a, a + cnt);
double ans = ;
int p = ;
for (int i = ; i < cnt; i++) {
if (Find(a[i].x) != Find(a[i].y)) {
ans += a[i].w ;
pre[Find(a[i].x)] = a[i].y;
p++;
if (p == c - ) break;
}
}
if (p == c - ) printf("%.1f\n", ans*);
else printf("oh!\n");
}
return ;
}

HZNU-ACM寒假集训Day8小结 最小生成树的更多相关文章

  1. 中南大学2019年ACM寒假集训前期训练题集(基础题)

    先写一部分,持续到更新完. A: 寒衣调 Description 男从戎,女守家.一夜,狼烟四起,男战死沙场.从此一道黄泉,两地离别.最后,女终于在等待中老去逝去.逝去的最后是换尽一生等到的相逢和团圆 ...

  2. 中南大学2019年ACM寒假集训前期训练题集(入门题)

    A: 漫无止境的八月 Description 又双叒叕开始漫无止境的八月了,阿虚突然问起长门在这些循环中团长哪几次扎起了马尾,他有多少次抓住了蝉等等问题,长门一共回复n个自然数,每个数均不超过1500 ...

  3. HZNU-ACM寒假集训Day3小结 搜索

    简单搜索 1.DFS UVA 548 树 1.可以用数组方式实现二叉树,在申请结点时仍用“动态化静态”的思想,写newnode函数 2.给定二叉树的中序遍历和后序遍历,可以构造出这棵二叉树,方法是根据 ...

  4. HZNU-ACM寒假集训Day1小结 STL 并查集

    常用STL 1.优先队列 priority_queue 内部是用堆(heap)实现的 priority_queue<int> pq; 默认为一个“越小的整数优先级越低的优先队列” 对于一些 ...

  5. HZNU-ACM寒假集训Day12小结 数论入门 题解

    算不出的等式 BJOI2012 看到这题 真没什么办法 无奈看题解 1.注意到p/q 联想到斜率 2.注意到 [ ] 联想到整点 注意到k在变化,构造一次函数 f(x)=p/q*x ,g(x)=q/p ...

  6. HZNU-ACM寒假集训Day12小结 数论入门

    符号说明 a|b      a整除b (a,b)    a与b的最大公因数 [a,b]     a与b的最小公倍数 pα||a    pα|a但pα+1∤a a≡b(mod m) a与b对模m同余 a ...

  7. HZNU-ACM寒假集训Day11小结 贪心

    1.刘汝佳紫书区间问题三大情况 1.选择不相交区间 贪心策略:一定要选择第一个区间 2.区间选点问题 贪心策略:取最后一个点 3.区间覆盖问题: n个闭区间,选择尽量少的区间覆盖一条指定线段[s,t] ...

  8. HZNU-ACM寒假集训Day10小结 单调栈-单调队列

    数据结构往往可以在不改变主算法的前提下题高运行效率,具体做法可能千差万别,但思路却是有规律可循 经典问题:滑动窗口  单调队列O(n) POJ 2823 我开始写的: TLE 说明STL的库还是有点慢 ...

  9. HZNU-ACM寒假集训Day10小结 树-树形DP

    树形DP 加分二叉树 洛谷P1040 注意中序遍历的特点:当根节点编号k时,编号小于k的都在其左子树上,编号大于k的都在右子树 转移方程 f[i,j]=max{f[i,k-1]*f[k+1,j]+d[ ...

随机推荐

  1. JuJu团队12月29号工作汇报

    JuJu团队12月29号工作汇报 JuJu   Scrum 团队成员 今日工作 剩余任务 困难 飞飞 数据处理 待安排 无 婷婷 调试代码 提升acc 无 恩升 修正evaluate 待完成 无 金华 ...

  2. 第一单元总结:基于基础语言、继承和接口的简单OOP

    前情提要 到目前为止,OO课程已经完成了前三次的作业,分别为: 第一次作业:简单多项式的构造和求导.[正则表达式][数据结构][排序] 第二次作业:含三角函数因子的复杂多项式的构造.求导和化简.[递归 ...

  3. 【LeetCode】基本计算器II

    [问题]实现一个基本的计算器来计算一个简单的字符串表达式的值.字符串表达式仅包含非负整数,+, - ,*,/ 四种运算符和空格  .整数除法仅保留整数部分. 输入: "3+2*2" ...

  4. PHPstudy2018 后门简单使用

    首先声明,仅为记录使用. 测试用例php-5.4.45 + Apache index.php 使用Firefox 浏览器,可以编辑并且重发http请求 打印出“net user” base64 加密后 ...

  5. JSONPath 表达式的使用

    一.JSONPath使用需要的包 <dependency> <groupId>com.jayway.jsonpath</groupId> <artifactI ...

  6. Java 布尔运算

    章节 Java 基础 Java 简介 Java 环境搭建 Java 基本语法 Java 注释 Java 变量 Java 数据类型 Java 字符串 Java 类型转换 Java 运算符 Java 字符 ...

  7. jenkins + gitlab 快速搭建(docker-compose) 时间,时区 同步

    记录一下吧   算打一下 tag   最近在整得 swarm + jenkins 实现自动化部署 回滚 #构建jenkins 镜像 #dockerfile:      docker build -t  ...

  8. Android之UI适配

    LinearLayout为线性布局按照垂直或者水平来进行排列,默认是按照水平来进行排列的,其中orientation属性是指定当前布局排列的方向 wrap_content为包裹内容   match_p ...

  9. Windows Server 2008 R2 ntoskrnl.exe 引起蓝屏故障,重新启动

    前不久在HP ProLiant DL360 G6的服务器上面安装了Windows Server 2008 R2,系统一到晚上凌晨就出现蓝屏.重启现象,并且在 C:\Windows\Minidump 目 ...

  10. tomcat端口号被占用,且杀进程不能够杀掉解决办法

    在电脑上安装了zookeeper以后,配置好tomcat启动发现端口号8009端口号被占用,报错如下: 采用netstat –ano 查询所有进程查看或者根据端口号查进程netstat -ano |f ...