ZJOI2007时态同步

ZJOI2007时态同步

描述

小Q在电子工艺实习课上学习焊接电路板。一块电路板由若干个元件组成,我们不妨称之为节点,并将其用数字1,2,3….进行标号。电路板的各个节点由若干不相交的导线相连接,且对于电路板的任何两个节点,都存在且仅存在一条通路(通路指连接两个元件的导线序列)。 在电路板上存在一个特殊的元件称为“激发器”。当激发器工作后,产生一个激励电流,通过导线传向每一个它所连接的节点。而中间节点接收到激励电流后,得到信息,并将该激励电流传向与它连接并且尚未接收到激励电流的节点。最终,激烈电流将到达一些“终止节点”——接收激励电流之后不再转发的节点。 激励电流在导线上的传播是需要花费时间的,对于每条边e,激励电流通过它需要的时间为te,而节点接收到激励电流后的转发可以认为是在瞬间完成的。现在这块电路板要求每一个“终止节点”同时得到激励电路——即保持时态同步。由于当前的构造并不符合时态同步的要求,故需要通过改变连接线的构造。目前小Q有一个道具,使用一次该道具,可以使得激励电流通过某条连接导线的时间增加一个单位。请问小Q最少使用多少次道具才可使得所有的“终止节点”时态同步?

输入

第一行包含一个正整数N,表示电路板中节点的个数。 第二行包含一个整数S,为该电路板的激发器的编号。 接下来N-1行,每行三个整数a , b , t。表示该条导线连接节点a与节点b,且激励电流通过这条导线需要t个单位时间。

输出

包含一个整数V,为小Q最少使用的道具次数。

样例输入[复制]

3

1

1 2 1

1 3 3

样例输出[复制]

2

提示

【数据规模】 对于40%的数据,N ≤ 1000 对于100%的数据,N ≤ 500000 对于所有的数据,te ≤ 1000000

标签

zjoi2007

 
 
 
一道简单的树上dp
考虑每个点到底部用的最大时间f[x],往上更新就会有取最大值然后获取答案,就完了
代码:
 1 #include<iostream>
 2 #include<cstdio>
 3 #define N 5000005
 4 using namespace std;
 5 long long ans=0;
 6 struct node{
 7     long long u,v,w;
 8 }e[N];
 9 long long first[N],nxt[N],cnt,f[N];
10 void add(long long u,long long v,long long w){
11     e[++cnt].u=u;
12     e[cnt].v=v;
13     e[cnt].w=w;
14     nxt[cnt]=first[u];
15     first[u]=cnt;
16 }
17 void dfs(long long x,long long father){
18     long long max0=0,sum=0,tot=0;
19     for(long long i=first[x];i;i=nxt[i]){
20         long long v=e[i].v;
21         if(v==father)continue;
22         dfs(v,x);
23         max0=max(max0,f[v]+e[i].w);
24         tot++;
25         sum+=f[v]+e[i].w;
26     }
27     ans+=max0*tot-sum;
28     f[x]=max0;
29 }
30 int main(){
31     ios::sync_with_stdio(false);
32     long long n,s;
33     cin>>n>>s;
34     for(long long i=1;i<n;i++){
35         long long a,b,t;
36         cin>>a>>b>>t;
37         add(a,b,t);
38         add(b,a,t);
39     }
40     dfs(s,-1);
41     cout<<ans;
42     return 0;
43 }

 

转载于:https://www.cnblogs.com/saionjisekai/p/9669575.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101410.html原文链接:https://javaforall.net

(0)
上一篇 2021年6月13日 下午2:00
下一篇 2021年6月13日 下午3:00


相关推荐

  • HashMap与ConcurrentHashMap的区别「建议收藏」

    HashMap与ConcurrentHashMap的区别「建议收藏」从JDK1.2起,就有了HashMap,正如前一篇文章所说,HashMap不是线程安全的,因此多线程操作时需要格外小心。在JDK1.5中,伟大的DougLea给我们带来了concurrent包,从此Map也有安全的了。ConcurrentHashMap具体是怎么实现线程安全的呢,肯定不可能是每个方法加synchronized,那样就变成了HashTable。从Conc

    2022年6月24日
    24
  • SLAM学习笔记(十九)开源3D激光SLAM总结大全——Cartographer3D,LOAM,Lego-LOAM,LIO-SAM,LVI-SAM,Livox-LOAM的原理解析及区别

    SLAM学习笔记(十九)开源3D激光SLAM总结大全——Cartographer3D,LOAM,Lego-LOAM,LIO-SAM,LVI-SAM,Livox-LOAM的原理解析及区别本文为我在浙江省北大信研院-智能计算中心-情感智能机器人实验室-科技委员会所做的一个分享汇报,现在我把它搬运到博客中。由于参与分享汇报的同事有许多是做其他方向的机器人工程师(包括硬件、控制等各方面并不是专门做SLAM的工程师),加上汇报的内容较多,因此在分享中我尽量使用简介的口语,而不出现复杂的公式。所以本文面向的是3D-slam方向的初学者。内容在整理中参考了许多链接,将放在最后。在文章结束后,我会把原PPT放在上面,需要者自取。另外打个广告,在slam方向有实习意愿的,请发送简历至zkyy8

    2022年8月23日
    11
  • java 贪吃蛇程序

    java 贪吃蛇程序公司的一个同事 关系不错 一起搞了一个 java 的贪吃蛇程序 公司之余的闲弄 java 代码 nbsp nbsp 窗体显示 nbsp nbsp nbsp nbsp class nbsp MyFrame nbsp extends nbsp JFrame nbsp nbsp nbsp nbsp public nbsp MyFrame nbsp nbsp nbsp nbsp setSize width height nbsp nbsp setTitl

    2026年3月18日
    2
  • Java学习之动态代理篇

    Java学习之动态代理篇0x00前言在后面的漏洞研究的学习中,必须要会的几个知识点。反射机制和动态代理机制。至于反射的前面已经讲到过了,这里就不做更多的赘述了。0x01动态代理这里先来讲一

    2021年12月12日
    57
  • html列表嵌套

    html列表嵌套Title 目录贴吧导航大事记载等级制度实名制度特点分析品牌价值手机贴吧贴吧客户端贴吧智能版平台推广官方平台贴吧推广列表嵌套 无序嵌套在有序中 直接在大的里面 根据

    2026年3月17日
    2
  • noscript 标签

    noscript 标签noscript标签中的元素中的内容只有在下列情况下才会显示出来:浏览器不支持脚本浏览器支持脚本,但脚本被禁用noscript标签是一个相当古老的标签,其被引入的最初目的是帮助老旧浏览器的平滑升级更替,因为早期的浏览器并不能支持JavaScript。noscript标签在不…

    2025年8月1日
    9

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号