2020牛客寒假算法基础集训营6 I.导航系统 (最小生成树)
https://ac.nowcoder.com/acm/contest/3007/I
题中给定的图必定是一棵树
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int maxn = ;
int n,m,s,cnt;
struct edge{
int from,to,w;
bool operator < (const edge &b) const{
return w < b.w;
}
}e[maxn*maxn];
struct node{
int u,v,w;
bool operator < (const node &b) const{
return w<b.w;
}
};
struct Node{
vector<int> v;
vector<int> w;
}g[maxn];
int fa[maxn],dis[maxn][maxn];
vector<node> ans;
int get(int x){
if(x == fa[x]) return x;
return fa[x] = get(fa[x]);
}
void merge(int x,int y){
int u = get(x),v = get(y);
if(u == v) return;
fa[u] = v;
}
void kruskal(){
sort(e+,e++m);
for(int i = ;i<=n;i++) fa[i] = i;
for(int i = ;i<=m;i++){
int x = get(e[i].from );
int y = get(e[i].to );
if(x == y) continue;
merge(x,y);
ans.push_back({e[i].from,e[i].to,e[i].w});
}
}
void addedge(int x,int y,int c){
e[cnt].from = x,e[cnt].to = y,e[cnt].w = c;
cnt++;
}
int vis[maxn],siz[maxn];
void dfs(int cur,int pos){//只需求出一个点到各个点的最小距离即可进行判断
vis[cur] = ;
siz[cur] = pos;
for(int i = ;i<g[cur].v.size();i++){
int v = g[cur].v[i];
if(!vis[v]) dfs(v,pos+g[cur].w[i]);
}
}
int main(){
cin>>n;
m = n*(n-),cnt = ;;
for(int i = ;i<=n;i++){
for(int j = ;j<=n;j++){
cin>>dis[i][j];
if(i == j) continue;
addedge(i,j,dis[i][j]);
}
}
kruskal();
for(int i = ;i<ans.size();i++){//建一个新图
node t = ans[i];
g[t.u].v.push_back(t.v);
g[t.v].v.push_back(t.u);
g[t.u].w.push_back(t.w);
g[t.v].w.push_back(t.w);
}
for(int i = ;i<=n;i++){
if(g[i].v.size() == ) {
s = i;break;
}
}
dfs(s,);
for(int i = ;i<=n;i++){
if(siz[i]!=dis[s][i]){
cout<<"No";return ;
}
}
sort(ans.begin(),ans.end());
cout<<"Yes"<<endl;
for(int i = ;i<ans.size();i++){
cout<<ans[i].w<<endl;
}
return ;
}
2020牛客寒假算法基础集训营6 I.导航系统 (最小生成树)的更多相关文章
- 2020牛客寒假算法基础集训营2 J题可以回顾回顾
2020牛客寒假算法基础集训营2 A.做游戏 这是个签到题. #include <cstdio> #include <cstdlib> #include <cstring ...
- 2020牛客寒假算法基础集训营1 J题可以回顾回顾
2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...
- 2020牛客寒假算法基础集训营4-F树上博弈
链接:https://ac.nowcoder.com/acm/contest/3005/F来源:牛客网 题目描述 现有一个 n 个点,n-1条边组成的树,其中 1 号点为根节点. 牛牛和牛妹在树上玩游 ...
- 2020牛客寒假算法基础集训营4-I 匹配星星【贪心】
链接:https://ac.nowcoder.com/acm/contest/3005/I来源:牛客网 示例1 输入 复制 2 1 1 0 2 2 1 2 1 1 0 2 2 1 输出 复制 1 1 ...
- 2020牛客寒假算法基础集训营1 F-maki和tree
链接:https://ac.nowcoder.com/acm/contest/3002/F来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...
- Applese 的毒气炸弹 G 牛客寒假算法基础集训营4(图论+最小生成树)
链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 Applese 的毒气炸弹 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262 ...
- 2020牛客寒假算法基础集训营5 G街机争霸
题目描述 哎,又是银首,要是你这个签到题少WA一发就金了 牛牛战队的队员打完比赛以后又到了日常甩锅的时间.他们心情悲伤,吃完晚饭以后,大家相约到一个街机厅去solo.牛牛和牛能进入了一个迷宫,这个迷宫 ...
- 2020牛客寒假算法基础集训营4 D:子段异或
D : 子段异或 考察点 : 位运算,前缀和,异或的性质和应用 坑点 : 0 - L 的异或值是 0 的话也是一个区间 相同的值可能有多个,那么这时候区间就会有多个(x * (x + 1) / 2) ...
- 2020牛客寒假算法基础集训营5 G.街机争霸 (bfs)
https://ac.nowcoder.com/acm/problem/201961 预处理出僵尸走的路径,僵尸走的周期长度应该为2k-2,在普通的bfs基础上加上一维表示时间,从当前位置x,y和和时 ...
随机推荐
- 【POJ - 3186】Treats for the Cows (区间dp)
Treats for the Cows 先搬中文 Descriptions: 给你n个数字v(1),v(2),...,v(n-1),v(n),每次你可以取出最左端的数字或者取出最右端的数字,一共取n次 ...
- mybatis 测试输出SQL语句到控制台配置
1: mybatis-config.xml <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE ...
- Git操作:绑定上传已存在的仓库到Github
之前使用github都是创建一个全新的仓库,然后clone下来用,但如果我已经有一个正在使用的仓库,想要绑定上传已存在的仓库到github,怎么做呢?其实在github创建仓库的时候会提示: …or ...
- js的reduce累加器
reduce为数组中每一个元素执行回调函数,不包括被删除或未被赋值的 https://www.jianshu.com/p/e375ba1cfc47
- LeetCode 面试题22. 链表中倒数第k个节点
题目链接:https://leetcode-cn.com/problems/lian-biao-zhong-dao-shu-di-kge-jie-dian-lcof/ 输入一个链表,输出该链表中倒数第 ...
- 逻辑卷管理(LVM)-迁移
逻辑卷管理(LVM)-迁移 更换卷组中逻辑卷中的一块硬盘流程:1确保卷组剩余空间大于需要更换的空间(缩减或添加添加新空间)-2迁移-3从卷组删除-4删除物理卷 #移除sdc1 1.查看卷组可用空间是否 ...
- 木兰国产编程语言 Mulan--附带下载地址
我国自主研发的 编程语言:木兰. 中国新闻网 : http://www.cas.cn/cm/202001/t20200116_4731821.shtml 说明介绍 百度一番后,发现没有下载地址,没有官 ...
- 安装Jenkins到Ubuntu(APT)
运行环境 系统版本:Ubuntu 16.04.4 LTS 软件版本:Jenkins-2.176.2 硬件要求:最低内存:256MB.磁盘:1GB 安装过程 1.配置APT-Jenkins存储库 APT ...
- Python函数进阶:闭包、装饰器、生成器、协程
返回目录 本篇索引 (1)闭包 (2)装饰器 (3)生成器 (4)协程 (1)闭包 闭包(closure)是很多现代编程语言都有的特点,像C++.Java.JavaScript等都实现或部分实现了闭包 ...
- 轻量级RPC设计与实现第二版
在上一个版本中利用netty实现了简单的一对一的RPC,需要手动设置服务地址,限制性较大. 在本文中,利用zookeeper作为服务注册中心,在服务端启动时将本地的服务信息注册到zookeeper中, ...