https://ac.nowcoder.com/acm/contest/3007/I

题中给定的图必定是一棵树    

容易发现,如果将输入的N(N-1)个距离看做N(N-1)条无向边的话,那么如果数据合法,原树就是这张新图的最小生成树。
证明:由于边权是非负的,可以考虑Kruskal算法的过程,每一次引入的边都是尽可能短的,所以一定是树中的边,通过简单的归纳即证。
 
 #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.导航系统 (最小生成树)的更多相关文章

  1. 2020牛客寒假算法基础集训营2 J题可以回顾回顾

    2020牛客寒假算法基础集训营2 A.做游戏 这是个签到题. #include <cstdio> #include <cstdlib> #include <cstring ...

  2. 2020牛客寒假算法基础集训营1 J题可以回顾回顾

    2020牛客寒假算法基础集训营1 这套题整体来说还是很简单的. A.honoka和格点三角形 这个题目不是很难,不过要考虑周全,面积是1,那么底边的长度可以是1也可以是2, 注意底边1和2会有重复的, ...

  3. 2020牛客寒假算法基础集训营4-F树上博弈

    链接:https://ac.nowcoder.com/acm/contest/3005/F来源:牛客网 题目描述 现有一个 n 个点,n-1条边组成的树,其中 1 号点为根节点. 牛牛和牛妹在树上玩游 ...

  4. 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 ...

  5. 2020牛客寒假算法基础集训营1 F-maki和tree

    链接:https://ac.nowcoder.com/acm/contest/3002/F来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言5242 ...

  6. Applese 的毒气炸弹 G 牛客寒假算法基础集训营4(图论+最小生成树)

    链接:https://ac.nowcoder.com/acm/contest/330/G来源:牛客网 Applese 的毒气炸弹 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262 ...

  7. 2020牛客寒假算法基础集训营5 G街机争霸

    题目描述 哎,又是银首,要是你这个签到题少WA一发就金了 牛牛战队的队员打完比赛以后又到了日常甩锅的时间.他们心情悲伤,吃完晚饭以后,大家相约到一个街机厅去solo.牛牛和牛能进入了一个迷宫,这个迷宫 ...

  8. 2020牛客寒假算法基础集训营4 D:子段异或

    D : 子段异或 考察点 : 位运算,前缀和,异或的性质和应用 坑点 : 0 - L 的异或值是 0 的话也是一个区间 相同的值可能有多个,那么这时候区间就会有多个(x * (x + 1) / 2) ...

  9. 2020牛客寒假算法基础集训营5 G.街机争霸 (bfs)

    https://ac.nowcoder.com/acm/problem/201961 预处理出僵尸走的路径,僵尸走的周期长度应该为2k-2,在普通的bfs基础上加上一维表示时间,从当前位置x,y和和时 ...

随机推荐

  1. IoU-aware Single-stage Object Detector for Accurate Localization

    网络的结构如下: 采用FPN结构,Backbone是RetinalNet,分成了P3~P7共5个Layer,分别训练不同尺寸的Box.每个Layer对应的Head有2个分支,包括一个单独的分支用来预测 ...

  2. vue及vant框架,多语言配置

    1.安装 vue-i18n,( cnpm install vue-i18n --save ) 2.在入口,main.js 中引入 (import Vuei18n from "vue-i18n ...

  3. " ModuleNotFoundError: No module named 'tkinter' "的解决方法

    踩坑场景 在使用pillow这个包处理图片的时候,运行程序,报错ModuleNotFoundError: No module named 'tkinter',遇到ModuleNotFoundError ...

  4. mysql 行级锁问题

    线上碰到存储过程死锁问题了,开始以为非主键查询 for update 会导致表锁,后来经过测试 innodb下for update索引生效的情况下 根据索引字段查询是行级锁,会将整个结果集进行上锁,直 ...

  5. IE浏览器中IFrame被加载两次问题的解决-sunziren

    本文为作者sunziren原创,首发博客园,转载请注明出处. 昨天遇到了一个问题,先上代码. var content = '<iframe src="www.baidu.com&quo ...

  6. maven的核心概念——继承

    15.1 为什么需要继承机制 由于非compile范围的依赖信息是不能在“依赖链”中传递的,所以有需要的工程只能单独配置.例如: Hello <dependency> <groupI ...

  7. 【python基础语法】数据类型:数值、字符串 (第2天课堂笔记)

    """ 数据类型: 一.数值类型:整数 浮点数 布尔值 二.序列类型:字符串.列表 元祖 三.散列类型:字典 集合 可变数据类型: 列表 字典 集合,可以改动内存地址数据 ...

  8. Beego 输出数据格式JSON、XML、JSONP

    JSON.XML.JSONP beego 当初设计的时候就考虑了 API 功能的设计,而我们在设计 API 的时候经常是输出 JSON 或者 XML 数据,那么 beego 提供了这样的方式直接输出: ...

  9. 《趣谈 Linux 操作系统》学习笔记(二):对 Linux 操作系统的理解

    首先,我们知道操作系统是管理和控制计算机硬件与软件资源的计算机程序.这里把操作系统想象为一个软件外包公司,其内核就相当于这家外包公司的老板,那么我们可以把自己的角色切换成这家外包公司的老板,设身处地的 ...

  10. 内网IPC$入侵加pstools之远程控制

    前言: IPC$(Internet process connection)是指内网里面的文件共享连接,通常很多机子的默认共享都是打开的,在cmd下使用命令net share可查看自己的IPC$是否打开 ...