原文链接https://www.cnblogs.com/zhouzhendong/p/CF806D.html

题目传送门 - CF806D

题意

  给定一个 n 个点的无向完全图,每一条边有一定的边权。

  对于它的一个生成树,我们定义一个节点的花费为该点到根的边权min 。

  一个生成树的权值为所有节点的花费之和。

  对于每一个节点,求出以他为根的最小生成树权值。

  $n\leq 2000$

题解

  首先,我们考虑找出权值最小的边。

  那么,一旦这条边被连到了根,剩下的所有点直接连向它就好了。

  假设有一个根,那么最优解之一 一定长成这样:

  其中根为最上面那个点,黑色点的上面直接连接的边权值为 min 。

  我们将所有点的权值先减掉min 。

  这之后我们只需要求出“将根和任意一个连接 0 边的节点连通的最小花费”即可。

  

  考虑将从黑色节点到根的边权依次写出来,假设是 $w_1,w_2,w_3,\cdots ,w_n$ ,那么有这样一个性质:

  最优解之一 一定满足 $\forall i>1, w_i<w_{i+1}$ 。

  因为如果存在一个不满足的 $i$ ,我们可以直接把第 $i-1$ 个接上去,把第 $i$ 个接到黑点上面。

  对于第一条边,当然不需要满足。

  设一个超级源点 S ,使他免费连向所有与 0 边直接相连的点,并与其他点没有边。

  于是,对于任何一个点 x,对于它连向的任意一个与 0 边直接相连的点 y ,将 d[x][S] 变成 min(d[x][S],2*d[x][y]) 即可。

  最后只要从 S 开始跑一下最短路就好了。

代码

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
LL read(){
LL x=0,f=0;
char ch=getchar();
while (!isdigit(ch))
f|=ch=='-',ch=getchar();
while (isdigit(ch))
x=(x<<1)+(x<<3)+(ch^48),ch=getchar();
return f?-x:x;
}
const int N=2005;
const int INF=2e9;
int n;
int g[N][N];
int tag[N],near[N];
int vis[N];
LL dis[N];
int main(){
n=read();
int Min=INF;
for (int i=1;i<=n;i++)
for (int j=i+1;j<=n;j++){
g[i][j]=g[j][i]=read();
Min=min(Min,g[i][j]);
}
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if (i!=j){
g[i][j]-=Min;
if (!g[i][j])
tag[i]=tag[j]=1;
}
int S=n+1;
for (int i=1;i<=n;i++)
g[S][i]=g[i][S]=tag[i]?0:INF;
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if (i!=j){
if (tag[i])
near[j]=1;
if (tag[j])
near[i]=1;
}
for (int i=1;i<=n;i++)
for (int j=1;j<=n;j++)
if (i!=j&&near[j])
g[S][i]=g[i][S]=min(g[i][S],2*g[i][j]);
for (int i=1;i<=n+1;i++)
vis[i]=0,dis[i]=1e15;
dis[S]=0;
for (int i=1;i<=n+1;i++){
int x=0;
for (int j=1;j<=n+1;j++)
if (!vis[j]&&(x==0||dis[j]<dis[x]))
x=j;
vis[x]=1;
for (int j=1;j<=n+1;j++)
if (!vis[j]&&dis[j]>dis[x]+g[x][j])
dis[j]=dis[x]+g[x][j];
}
for (int i=1;i<=n;i++)
cout << dis[i]+(LL)Min*(n-1) << endl;
return 0;
}

  

Codeforces 806 D. Perishable Roads Dijkstra的更多相关文章

  1. Codeforces 806 D.Prishable Roads

    Codeforces 806 D.Prishable Roads 题目大意:给出一张完全图,你需要选取其中的一些有向边,连成一个树形图,树形图中每个点的贡献是其到根节点路径上每一条边的边权最小值,现在 ...

  2. Codeforces 191C Fools and Roads(树链拆分)

    题目链接:Codeforces 191C Fools and Roads 题目大意:给定一个N节点的数.然后有M次操作,每次从u移动到v.问说每条边被移动过的次数. 解题思路:树链剖分维护边,用一个数 ...

  3. [CF773D]Perishable Roads

    [CF773D]Perishable Roads 题目大意: 一个\(n(n\le2000)\)个点的完全图\(G\),定义\(d(x)\)为生成树上点\(x\)到根路径上的最小边权.问图\(G\)的 ...

  4. Codeforces.567E.President and Roads(最短路 Dijkstra)

    题目链接 \(Description\) 给定一张有向图,求哪些边一定在最短路上.对于不一定在最短路上的边,输出最少需要将其边权改变多少,才能使其一定在最短路上(边权必须为正,若仍不行输出NO). \ ...

  5. ROADS+dijkstra的灵活运用+POJ

    ROADS Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 10742   Accepted: 3949 Descriptio ...

  6. Codeforces Gym 100338C Important Roads 最短路+Tarjan找桥

    原题链接:http://codeforces.com/gym/100338/attachments/download/2136/20062007-winter-petrozavodsk-camp-an ...

  7. codeforces 711D D. Directed Roads(dfs)

    题目链接: D. Directed Roads time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  8. Codeforces 711 D. Directed Roads (DFS判环)

    题目链接:http://codeforces.com/problemset/problem/711/D 给你一个n个节点n条边的有向图,可以把一条边反向,现在问有多少种方式可以使这个图没有环. 每个连 ...

  9. Codeforces 746 G. New Roads

    题目链接:http://codeforces.com/contest/746/problem/G mamaya,不知道YY了一个什么做法就这样过去了啊 2333 首先我显然可以随便构造出一棵树满足他所 ...

随机推荐

  1. luasocket 安装记录 (FS1.6)

    说明: 想通过Lua 脚本实现 http.默认 FS 的 mod_lua 中没有对socket 的支持,如下的操作为lua 添加 socket的支持. 一.下载 luasocket 包: # wget ...

  2. springboot:扩展类型转换器

    需求:提交一个字符串到后端的java.sql.Time类型,就报错了: Failed to convert property value of type [java.lang.String] to r ...

  3. Bootstrap -- 模态框实现拖拽移动

    ### 这里实现这个效果 需要引入 jquery-ui.min.js类库 jquery-ui.min.css样式 使用它提供的draggable()方法实现 ### 菜鸟教程 http://www.r ...

  4. lua 复制table

    cocos2d-lua提供了复制方法clone(),源码如下: function clone(object) local lookup_table = {} local function _copy( ...

  5. JS跨域ajax访问

    方式1:jsonp解决跨域访问 需要服务和js配合 服务 [WebMethod] public void HelloWorld2(string name) { HttpContext.Current. ...

  6. Confluence 6 home 修改 Home 目录的位置

    当 Confluence 第一次启动的时候,Confluence 将会读取 confluence-init.properties 文件并从这个文件中确定如何去查找 Home 目录. 希望修改 home ...

  7. Confluence 6 配置 workbox 通知

    你可以在你的 Confluence workbox 中查看和管理应用内的通知和任务.更多的,你可以在 Confluence workbox 中从接收到从 JIRA 和其他 Confluence 服务器 ...

  8. Linux基础实操六

    实操一: 临时配置网络(ip,网关,dns)+永久配置 #ifconfig ens33 192.168.145.134/24 #vim /etc/resolv.conf #route add defa ...

  9. CF451E

    一道不错的题,对排列组合能力的要求较高 题意:给定s个相同的小球放在n个不同的盒子里,可以不放,每个盒子有一个放的上限,求一共有多少种放法 解析:首先考虑没有上限的情况,这里比较好解决,采用隔板法,可 ...

  10. Centos6.10部署TeamViewer

    1.在官网下载支持Linux系统的包,建议下载TeamViewer12的包,官网URL:https://www.teamviewer.com/cn/download/linux/ 2.将下载的软件包导 ...