【BZOJ-2435】道路修建 (树形DP?)DFS

2435: [Noi2011]道路修建

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 3115  Solved: 1002
[Submit][Status][Discuss]

Description

在 W 星球上有 n 个国家。为了各自国家的经济发展,他们决定在各个国家
之间建设双向道路使得国家之间连通。但是每个国家的国王都很吝啬,他们只愿
意修建恰好 n – 1条双向道路。 每条道路的修建都要付出一定的费用, 这个费用等于道路长度乘以道路两端的国家个数之差的绝对值。例如,在下图中,虚线所示道路两端分别有 2 个、4个国家,如果该道路长度为 1,则费用为1×|2 – 4|=2。图中圆圈里的数字表示国家的编号。


由于国家的数量十分庞大,道路的建造方案有很多种,同时每种方案的修建
费用难以用人工计算,国王们决定找人设计一个软件,对于给定的建造方案,计
算出所需要的费用。请你帮助国王们设计一个这样的软件。

Input

输入的第一行包含一个整数n,表示 W 星球上的国家的数量,国家从 1到n
编号。接下来 n – 1行描述道路建设情况,其中第 i 行包含三个整数ai、bi和ci,表
示第i 条双向道路修建在 ai与bi两个国家之间,长度为ci。

Output

输出一个整数,表示修建所有道路所需要的总费用。

Sample Input

6
1 2 1
1 3 1
1 4 2
6 3 1
5 2 1

Sample Output

20

HINT

n = 1,000,000 1≤ai, bi≤n 
0 ≤ci≤ 10^6

Source

Day2

Solution

看WC的讲义上似乎树形DP中有此题...

然而,直接暴力的DFS求出每个节点的size[u],那么另一边的size[v]=n-size[u]

那么可以直接累计答案...

坑点:注意转longlong,(abs中间也要强转longlong..虽然不明觉厉)

Code

#include<iostream>
#include<cstring>
#include<cmath>
#include<cstdio>
#include<algorithm>
using namespace std;
int read()
{int x=0,f=1; char ch=getchar();while (ch<'0' || ch>'9') {if (ch=='-') f=-1; ch=getchar();}while (ch>='0' && ch<='9') {x=x*10+ch-'0'; ch=getchar();}return x*f;
}
#define maxn 1100000
int n;long long ans;
struct EdgeNode{int next,to,from,len;}edge[maxn<<1];
int head[maxn],cnt;
void add(int u,int v,int w)
{cnt++;edge[cnt].to=v;edge[cnt].next=head[u];head[u]=cnt;edge[cnt].len=w;edge[cnt].from=u;
}
void insert(int u,int v,int w) {add(u,v,w); add(v,u,w);}
int size[maxn];
void DFS(int now,int fa,long long dis)
{size[now]=1;for (int i=head[now]; i; i=edge[i].next)if (edge[i].to!=fa){DFS(edge[i].to,now,(long long)edge[i].len);size[now]+=size[edge[i].to];}ans+=(long long)(dis*(long long)abs((long long)(size[now]-(n-size[now]))));
}
int main()
{n=read();for (int u,v,w,i=1; i<=n-1; i++)u=read(),v=read(),w=read(),insert(u,v,w);DFS(1,0,0LL);printf("%lld\n",ans);return 0;
}

一开始想到WC的讲义上的树形DP,那么考虑树形DP..想了想,size这个东西是不是可以直接DFS出来,直接算答案啊?难道有反例?于是划拉了几个确定似乎没有,然后试了试愉快的AC了...SMG

转载于:https://www.cnblogs.com/DaD3zZ-Beyonder/p/5506671.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/470637.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSRF跨站请求伪造

一、CSRF跨站请求伪造 CSRF全拼为Cross Site Request Forgery&#xff0c;译为跨站请求伪造。 CSRF指攻击者盗用了你的身份&#xff0c;以你的名义发送恶意请求。 包括&#xff1a;以你名义发送邮件&#xff0c;发消息&#xff0c;盗取你的账号&#xff0c;甚至于购买商品&a…

升级 ubuntu_Ubuntu 19.04 已经到期!现有用户必须升级到 Ubuntu 19.10

Ubuntu 19.04 已在 2020 年 1 月 23 日到期&#xff0c;这意味着运行 Ubuntu 19.04 的系统将不再会接收到安全和维护更新&#xff0c;因此将使其容易受到攻击。-- Abhishek Prakash(作者)Ubuntu 19.04 发布于 2019 年 4 月 18 日。由于它不是长期支持(LTS)版本&#xff0c;因此…

Chapter7-3_BERT and its family - ELMo, BERT, GPT, XLNet, MASS, BART, UniLM, ELECTRA, and more

文章目录1 How to pre-train2 Predict next token3 Mask Input4 seq2seq的pre-train model5 ELECTRA6 Sentence Embedding本文为李弘毅老师【BERT and its family - ELMo, BERT, GPT, XLNet, MASS, BART, UniLM, ELECTRA, and more】的课程笔记&#xff0c;课程视频youtube地址…

python中split函数_python strip()函数和Split函数的用法总结

strip函数原型 声明&#xff1a;s为字符串&#xff0c;rm为要删除的字符序列. 只能删除开头或是结尾的字符或是字符串。不能删除中间的字符或是字符串。 s.strip(rm) 删除s字符串中开头、结尾处&#xff0c;位于 rm删除序列的字符 s.lstrip(rm) 删除s字符串中开头处&#xff0c…

express项目搭建 初始化详细步骤

案例 一、对每一个POST请求都设置CSRF防护 实际上&#xff0c;不仅仅转账需要CSRF防护&#xff0c;每一个post请求都需要做csrf的防护措施。 webA项目中的app.js&#xff1a; const router express.Router();router.all("/register",(res,req)>{.... })funct…

Chapter7-4_來自獵人暗黑大陸的模型 GPT-3

文章目录1 为何来自暗黑大陆2 GPT-3的野心3 GPT-3的效果4 Beyond GPT-3本文为李弘毅老师【來自獵人暗黑大陸的模型 GPT-3】的课程笔记&#xff0c;课程视频youtube地址&#xff0c;点这里&#x1f448;(需翻墙)。 下文中用到的图片均来自于李宏毅老师的PPT&#xff0c;若有侵权…

二、PHP框架Laravel学习笔记——路由的定义和控制器

一&#xff0e;路由的定义 什么是路由&#xff1f;路由就是提供接受 HTTP 请求的路径&#xff0c;并和程序交互的功能&#xff1b; 简单点理解&#xff0c;就是为了提供访问程序的 URL 地址&#xff0c;所做的一些设置工作&#xff1b; phpstorm 支持 cmd 操作&#xff0c;左…

Chapter7-5_Multilingual BERT

文章目录1 什么是Multilingual BERT2 Zero-shot Reading Comprehension3 Cross-lingual Alignment4 How alignment happens本文为李弘毅老师【Multilingual BERT】的课程笔记&#xff0c;课程视频youtube地址&#xff0c;点这里&#x1f448;(需翻墙)。 下文中用到的图片均来自…

deepin tim(wine)无法安装_浅析国产操作系统深度deepin

经过两天的努力&#xff0c;终于实现了win10下跟deepin 的双系统&#xff0c;经过我实际操作&#xff0c;发现win7环境下装双系统还是有问题的。虽然deepin系统也能安装成功&#xff0c;但是win系统却是无法顺利启动&#xff0c;一直卡在系统初始界面无限循环。而更换win10之后…

三、PHP框架Laravel学习笔记——路由参数、重定向、视图

一&#xff0e;路由参数 我们已经学习了部分路由参数的功能&#xff0c;比如动态传递{id}&#xff1b;那么&#xff0c;有时这个参数需要进行约束&#xff0c;我们可以使用正则来限定必须是数字&#xff1b; Route::get(task/read/{id}, TaskControllerread) ->where(id, …

Chapter7-6_Text Style Transfer

文章目录1 什么是Text Style Transfer2 Cycle GAN2.1 Gumbel-softmax2.2 Continuous Input for Discriminator2.3 Reinforcement Learning2.4 效果3 Star GAN4 Feature Disentangle5 Unsupervised Abstractive Summarization6 Unsupervised Translation7 Unsupervised Speech R…

Student学生管理系统

1.定义各个层 2.添加各个层之间的引用 DAL 层调用Model BLL层调用DAL和Model UI层调用BLL和Model层 Model层供各个层调用 3.根据数据库建立实体类,每张表对应一个实体类 4.在DAL层调用MyTool类和SQLhelper类,添加system.Configuration 引用 并编写app.config 在SqlHelper类调用…

一、PHP框架Laravel——入门和安装

一&#xff0e;版本化方案 Laravel 框架是一款简洁、优秀且优雅的 PHP 开发框架&#xff1b;Laravel 到底怎么读&#xff0c;由于不是真实的单词&#xff0c;导致争论较多目前已知&#xff1a;[lrəvel][lɑːrəvel][lɑːrvl]有这几种&#xff1b;Laravel 从 6.x 开始进入到…

iscsi没有可用于使用快速连接登陆的目标_【解密】5G商用在即 OPPO快速网络切换方法;高管宣布华为河图商标注册成功;小米折叠屏专利曝光 类似于摩托罗拉Razr...

1.【专利解密】5G商用在即 OPPO快速网络切换方法2.好消息&#xff01;高管宣布华为河图商标注册成功3.小米折叠屏专利曝光 类似于摩托罗拉Razr4.索尼Xperia提交新专利 上下双升降结构1.【专利解密】5G商用在即 OPPO快速网络切换方法【嘉德点评】OPPO发明的网络切换专利&#xf…

搞懂DEtection TRanformer(DETR)

文章目录1 bipartite matching loss2 模型总体框架2.1 backbone2.2 transformer2.2.1 encoder2.2.2 decoder2.2.3 prediction heads3 模型效果参考文献本文描述了笔者在阅读了一些文献之后&#xff0c;对 End-to-end Object Detection with Transformers(DETR) 的理解。DETR是一…

四、PHP框架Laravel学习笔记——路由命名和分组

一&#xff0e;路由命名 给一个制定好的路由进行命名&#xff0c;可以生成 URL 地址或进行重定向&#xff1b; Route::get(task, TaskControllerindex)->name(task.index); 在控制器区域&#xff0c;使用助手函数 route()来获取路由生成的 URL 地址&#xff1b; //生成 ur…

echart 数据点可以加链接吗_地理可视化就这么简单、酷炫,蚂蚁金服AntV 空间数据可视化引擎 L72.0发布...

导读L7 是由蚂蚁金服 AntV 数据可视化团队推出的基于 WebGL 的开源大规模地理空间数据可视分析开发框架。L7 中的 L 代表 Location&#xff0c;7 代表世界七大洲&#xff0c;寓意能为全球位置数据提供可视分析的能力。L7 以图形符号学为理论基础&#xff0c;将抽象复杂的空间数…

论文阅读 - Large-scale weakly-supervised pre-training for video action recognition

文章目录1 概述2 数据的收集方式3 使用的模型4 预训练时的一系列问题4.1 预训练的数据是不是越多越好&#xff1f;4.2 用于预训练的模型是不是越大越好&#xff1f;4.3 预训练数据的标签种类和数量是不是越多越好&#xff1f;4.4 用于预训练的每个video有长有短&#xff0c;时长…

excel记账本模板_原来这才是老板最喜欢看的财务报表!这些模板送你,录入自动生成...

【原来这才是老板最喜欢看的财务报表&#xff01;这些模板送你&#xff0c;录入自动生成】都说财务报表做好&#xff0c;会计下班会很早&#xff01;财务报表做的妙&#xff0c;升职加薪少不了&#xff01;会计每到下班拖后腿的就是要整理好各种报表然后发给领导&#xff0c;会…

五、PHP框架Laravel学习笔记——回退、当前路由、单行为

一&#xff0e;单行为控制器 之前的课程&#xff0c;我们简单的创建和定义了控制器&#xff0c;并继承了控制器基类&#xff1b;为何要继承基类&#xff1f;因为继承基类后&#xff0c;可以使用基类的方法&#xff0c;比如中间件等&#xff1b;继承基类后除了支持中间件快捷使…