[Luogu] P1131 [ZJOI2007]时态同步

本文探讨了在电路板设计中实现所有终止节点时态同步的问题。通过分析电路板的结构,提出了一种基于贪心策略的解决方案,确保每个终止节点能够同时接收到激励电流,实现了电路板的时态同步。

题目描述

题目描述

Q在电子工艺实习课上学习焊接电路板。一块电路板由若干个元件组成,我们不妨称之为节点,并将其用数字1,2,3…进行标号。电路板的各个节点由若干不相交的导线相连接,且对于电路板的任何两个节点,都存在且仅存在一条通路(通路指连接两个元件的导线序列)。

在电路板上存在一个特殊的元件称为“激发器”。当激发器工作后,产生一个激励电流,通过导线传向每一个它所连接的节点。而中间节点接收到激励电流后,得到信息,并将该激励电流传向与它连接并且尚未接收到激励电流的节点。最终,激励电流将到达一些“终止节点”――接收激励电流之后不再转发的节点。

激励电流在导线上的传播是需要花费时间的,对于每条边e,激励电流通过它需要的时间为te,而节点接收到激励电流后的转发可以认为是在瞬间完成的。现在这块电路板要求每一个“终止节点”同时得到激励电路――即保持时态同步。由于当前的构造并不符合时态同步的要求,故需要通过改变连接线的构造。目前小Q有一个道具,使用一次该道具,可以使得激励电流通过某条连接导线的时间增加一个单位。请问小Q最少使用多少次道具才可使得所有的“终止节点”时态同步?

题目解析

树形DP吗?完全不会不知道为什么要用。

贪心就可以了

首先明确一个性质:

要使得所有叶子的深度相同,那么对于任意一个点,每个子树的深度都必须相同。

证明:

可以用反证法,如果有一个节点x,它的子树的深度各不相同,那这些子树的叶节点到x的距离一定不同。那么这些不同的距离分别加上x到root的距离也一定不同。

与题目要求不符,所以要满足题目要求,任意一个节点的子树深度必然相同。

证毕。

策略

既然我们要保证每个节点所有子树深度相同,我们可以贪心的处理每个点,把深度用道具强行补到相同。

在dfs的时候,把当前搜索的这个点的子树中最深的深度记为maxdeep。

之后ans += ∑(maxdeep - 这个点的其它子树的深度);

细节看代码吧

Code 

#include<iostream>
#include<cstdio>
#include<cctype>
#define int long long//不开LL会66分的
using namespace std;

const int MAXN = 500000 + 5;

struct Edge {
    int nxt;
    int to,w;
} l[MAXN<<1];

int n,root,ans;
int head[MAXN],cnt;
int maxdeep[MAXN];

inline int rd() {
    int x=0,f=1;char ch=getchar();
    while(!isdigit(ch)) {f=(ch=='-')?-1:1;ch=getchar();}
    while(isdigit(ch)) {x=x*10+ch-'0';ch=getchar();}
    return x*f;
}

inline void add(int x,int y,int z) {
    cnt++;
    l[cnt].nxt = head[x];
    l[cnt].to = y;
    l[cnt].w = z;
    head[x] = cnt;
    return;
}

void dfs(int x,int from) {
    int son = maxdeep[x];//提前记一下,因为下面更新要用到原来maxdeep[x]的值,所以用son来记最大的深度
    for(int i = head[x];i;i = l[i].nxt) {
        if(l[i].to == from) continue;
        maxdeep[l[i].to] = maxdeep[x] + l[i].w;
        dfs(l[i].to,x);
        son = max(son,maxdeep[l[i].to]);
    }
    maxdeep[x] = son;
    for(int i = head[x];i;i = l[i].nxt) {
        if(l[i].to == from) continue;
        ans += maxdeep[x] - maxdeep[l[i].to];
    }
    return;
}

signed main() {
    scanf("%lld%lld",&n,&root);
    int x,y,z;
    for(register int i = 1;i < n;i++) {
        x = rd(), y = rd(), z = rd();
        add(x,y,z), add(y,x,z);
    }
    dfs(root,-1);
    printf("%lld\n",ans);
    return 0;
}

 

转载于:https://www.cnblogs.com/floatiy/p/9829056.html

(1)普通用户端(全平台) 音乐播放核心体验: 个性化首页:基于 “听歌历史 + 收藏偏好” 展示 “推荐歌单(每日 30 首)、新歌速递、相似曲风推荐”,支持按 “场景(通勤 / 学习 / 运动)” 切换推荐维度。 播放页功能:支持 “无损音质切换、倍速播放(0.5x-2.0x)、定时关闭、歌词逐句滚动”,提供 “沉浸式全屏模式”(隐藏冗余控件,突出歌词与专辑封面)。 多端同步:自动同步 “播放进度、收藏列表、歌单” 至所有登录设备(如手机暂停后,电脑端打开可继续播放)。 音乐发现与管理: 智能搜索:支持 “歌曲名 / 歌手 / 歌词片段” 搜索,提供 “模糊匹配(如输入‘晴天’联想‘周杰伦 - 晴天’)、热门搜索词推荐”,结果按 “热度 / 匹配度” 排序。 歌单管理:创建 “公开 / 私有 / 加密” 歌单,支持 “批量添加歌曲、拖拽排序、一键分享到社交平台”,系统自动生成 “歌单封面(基于歌曲风格配色)”。 音乐分类浏览:按 “曲风(流行 / 摇滚 / 古典)、语言(国语 / 英语 / 日语)、年代(80 后经典 / 2023 新歌)” 分层浏览,每个分类页展示 “TOP50 榜单”。 社交互动功能: 动态广场:查看 “关注的用户 / 音乐人发布的动态(如‘分享新歌感受’)、好友正在听的歌曲”,支持 “点赞 / 评论 / 转发”,可直接点击动态中的歌曲播放。 听歌排行:个人页展示 “本周听歌 TOP10、累计听歌时长”,平台定期生成 “全球 / 好友榜”(如 “好友中你本周听歌时长排名第 3”)。 音乐圈:加入 “特定曲风圈子(如‘古典音乐爱好者’)”,参与 “话题讨论(如‘你心中最经典的钢琴曲’)、线上歌单共创”。 (2)音乐人端(创作者中心) 作品管理: 音乐上传:支持 “无损音频(FLAC/WAV)+ 歌词文件(LRC)+ 专辑封面” 上传,填写 “歌曲信息
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值