有一棵包含n个节点和n-1条边的树,规定树链(u,v)为树上从u到v的简单路径。
树的每条边上都有一个正整数,这个正整数被称作这条边的颜色,规定一条树链的权值w(u,v)为这条树链上所有边的颜色的代数和。
而整棵树的权值为所有不同的树链的权值的代数和。
已知所有边的颜色集合恰好为1到n-1这n-1个不同的正整数,请你为每条边安排一种颜色,使得这棵树的权值尽量小,你不需要给出具体方案,只需要求出这个最小的权值即可。
输入描述:
测试数据第一行,是一个正整数n(1 \le n \le 10^5)n(1≤n≤10
5
),表示树的节点个数
接下来n-1行,每行两个用空格隔开的整数u,v,表示树上有一条边连接u和v
输出描述:
一个整数,表示了这棵树的最小的权值。
示例1
输入
复制
4
1 2
2 3
3 4
输出
复制
19

思路

我们求出每条边需要经过的次数然后将这些次数进行排序然后再乘以(n-1)…1这就是我们的贪心策略,所以这题就转换成需要求每条边经过的次数,于是采用dfs搜索每个点的子节点数,于是该边经过的次数就为该点的子节点数*(所有节点数-该点子节点数)

代码

#include<bits/stdc++.h>
#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#define R __int128
using namespace std;
typedef long long ll;
typedef pair<int,int> PII;
const ll INF=0x7f7f7f7f;
const int maxn=2e6+10;
const ll mod=1e9+7;
bool vis[maxn];
ll s,d,siz[maxn];
ll n,m,k;
ll c[maxn];
bool cmp(ll x,ll y){return x>y;
}
vector<ll> g[maxn];
void dfs(ll x){siz[x]=1;for(int i=0;i<g[x].size();i++){ll j=g[x][i];if(!vis[j]){vis[j]=true;dfs(j);siz[x]+=siz[j];}}
}
void solve() {ll ans=0;cin>>n;for(int i=1;i<n;i++){ll a,b;cin>>a>>b;g[a].push_back(b);g[b].push_back(a);}vis[1]=true;dfs(1);for(int i=2;i<=n;i++){cout<<siz[i]<<endl;c[i-1]=siz[i]*(n-siz[i]);}sort(c+1,c+n,cmp);for(int i=1;i<n;i++){ans+=c[i]*i*1ll;}cout<<ans<<endl;
}
int main() {solve();
}
/**  ┌───┐   ┌───┬───┬───┬───┐ ┌───┬───┬───┬───┐ ┌───┬───┬───┬───┐ ┌───┬───┬───┐*  │Esc│   │ F1│ F2│ F3│ F4│ │ F5│ F6│ F7│ F8│ │ F9│F10│F11│F12│ │P/S│S L│P/B│  ┌┐    ┌┐    ┌┐*  └───┘   └───┴───┴───┴───┘ └───┴───┴───┴───┘ └───┴───┴───┴───┘ └───┴───┴───┘  └┘    └┘    └┘*  ┌───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───┬───────┐ ┌───┬───┬───┐ ┌───┬───┬───┬───┐*  │~ `│! 1│@ 2│# 3│$ 4│% 5│^ 6│& 7│* 8│( 9│) 0│_ -│+ =│ BacSp │ │Ins│Hom│PUp│ │N L│ / │ * │ - │*  ├───┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─────┤ ├───┼───┼───┤ ├───┼───┼───┼───┤*  │ Tab │ Q │ W │ E │ R │ T │ Y │ U │ I │ O │ P │{ [│} ]│ | \ │ │Del│End│PDn│ │ 7 │ 8 │ 9 │   │*  ├─────┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴┬──┴─────┤ └───┴───┴───┘ ├───┼───┼───┤ + │*  │ Caps │ A │ S │ D │ F │ G │ H │ J │ K │ L │: ;│" '│ Enter  │               │ 4 │ 5 │ 6 │   │*  ├──────┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴─┬─┴────────┤     ┌───┐     ├───┼───┼───┼───┤*  │ Shift  │ Z │ X │ C │ V │ B │ N │ M │< ,│> .│? /│  Shift   │     │ ↑ │     │ 1 │ 2 │ 3 │   │*  ├─────┬──┴─┬─┴──┬┴───┴───┴───┴───┴───┴──┬┴───┼───┴┬────┬────┤ ┌───┼───┼───┐ ├───┴───┼───┤ E││*  │ Ctrl│    │Alt │         Space         │ Alt│    │    │Ctrl│ │ ← │ ↓ │ → │ │   0   │ . │←─┘│*  └─────┴────┴────┴───────────────────────┴────┴────┴────┴────┘ └───┴───┴───┘ └───────┴───┴───┘*/

小白月赛23-G 树上求和相关推荐

  1. 牛客小白月赛9: D. 树上求和(dfs序+线段树)

    链接:https://ac.nowcoder.com/acm/contest/275/D 来源:牛客网 题目描述 给你一棵根为1的有N个节点的树,以及Q次操作. 每次操作诸如: 1 x y:将节点x所 ...

  2. 牛客小白月赛28 J.树上行走

    牛客小白月赛28 J.树上行走 题目链接 题目描述 牛牛苦练武功绝学--轻功水上漂,最终没有练成,但是他学会了在树上行走的本领. 这天,牛牛落入了敌人的陷阱,身后有巨石追击,面前有n个点,n-1条边连 ...

  3. 牛客小白月赛21 G.Game

    牛客小白月赛21 G.Game 题目描述 Nancy喜欢博弈! Johnson和Nancy得到了一个神奇的多重集合,仅包含一个正整数n,两个人轮流进行操作. 一次操作可以将集合中一个数字分解为它的任意 ...

  4. 牛客小白月赛6 G.指纹锁

    牛客小白月赛6 G.指纹锁 题目链接 题目描述 HA实验有一套非常严密的安全保障体系,在HA实验基地的大门,有一个指纹锁. 该指纹锁的加密算法会把一个指纹转化为一个不超过1e7的数字,两个指纹数值之差 ...

  5. 牛客小白月赛23 C.完全图

    牛客小白月赛23 C.完全图 题目链接 题目描述 在图论的数学领域,完全图是一个简单的无向图,其中每对不同的顶点之间都恰连有一条边相连.----百度百科 现在给定一个包含 n 个顶点的完全图,你可以删 ...

  6. 牛客小白月赛1 G .あなたの蛙は旅⽴っています

    牛客小白月赛1 G .あなたの蛙は旅⽴っています 题目链接 题目描述 あなたの蛙は旅立っています! 你的蛙正在考虑它应该按怎样的路线去旅行.这些景点可以抽象为 N N N 个镶嵌着的六边形.每个景点 ...

  7. 牛客小白月赛28 G.牛牛和字符串的日常

    牛客小白月赛28 G.牛牛和字符串的日常 题目链接 题目描述 牛牛每天都要做的事就是读书,从书里找自己喜欢的句子,他每天都会去读一本书,如果牛牛今天读的书的某连续 k k k 个字符刚好是牛牛喜欢句子 ...

  8. 牛客小白月赛23(A、B

    牛客小白月赛 A.膜法记录 题意: 给n行m列的矩阵,矩阵中的每个位置都可能有敌人 现在你能消灭a行和b列的敌人,问是否有可能将所有敌人都消灭. 数据范围:n<=20,m<=1e5 思路: ...

  9. 牛客小白月赛2 G 文 【模拟】

    链接:https://www.nowcoder.com/acm/contest/86/G 来源:牛客网 题目描述 Sεlιнα(Selina) 开始了新一轮的男友海选.她要求她的男友要德智体美劳样样都 ...

  10. 牛客网 牛客小白月赛2 G.文

    G.文 链接:https://www.nowcoder.com/acm/contest/86/G 这个题wa了一发,有点智障,浮点数,式子里面要*1.0,忘了,然后wa了,改了就过了(脑子有坑) 代码 ...

最新文章

  1. android window 大小,android popupWindow 中宽度莫名很大,求帮助?
  2. React demo:express、react-redux、react-router、react-roter-redux、redux-thunk(一)
  3. 算法模板-对称性递归
  4. ionic3 cordova ionic-native插件
  5. 三行代码实现冒泡排序算法
  6. python字符串格式化 说明符顺序_python实践分享:格式化字符串时使用.format方式还是“%”...
  7. 力扣-747 至少是其他数字两倍的最大数
  8. 【leetcode_easy】590. N-ary Tree Postorder Traversal
  9. Julia: feather格式和hdf5格式比较
  10. Dell Precision M4800 AppleALC声卡驱动修复教程
  11. RTI -- 实时中断
  12. word加了脚注,分节符(连续)后的内容,跳到下一页
  13. 关于LTE网络质量的参数
  14. webpack坑系列--安装webpack-cli
  15. 《敏捷开发一千另一夜》 读后感1
  16. Looking for the Devil in the Details:Learning Trilinear Attention Sampling Network for FGVC-笔记
  17. 华为手机备份app从内部恢复
  18. 用Python实现各类重复性工作的自动化
  19. 精选100个Python实战项目案例,送给缺乏实战经验的你
  20. 新版FPC摄像头测评 OV7725 OV7670 OV9650 OV9655 OV5640 OV5642 OV2640 OV3640 MT9D112

热门文章

  1. 斯坦福AI2021报告出炉!详解七大热点,论文引用中国首超美国
  2. matlab烟雾监测,Matlab火焰烟雾检测(GUI)
  3. MQ2烟雾传感器模块——stm32f103
  4. VVIC平台API接口:item_get - 根据ID取商品详情
  5. HDU3507打印文章 斜率优化入门
  6. Centos 7 无法上网的解决办法
  7. Java实现 LeetCode 520 检测大写字母
  8. 烂泥:linux文件同步之rsync学习(一)
  9. 后台系统设计——角色权限
  10. 可使用计算机打印的方式替代,邮政投递员高级理论知识试卷02