换根dp

换根dp

什么是换根dp,如果已知以某一个点为根节点的树的总深度之和,如何求以其它节点为根的总深度之和。

换根dp可以用于求解有n个节点的树,以编号1-n为根节点的树的总深度之和的最小值或最大值。

如何求呢?

  • 首先先求出以1为根节点的树的总深度size和每个节点的深度h,这个可以一遍dfs求出。
void dfs1(int s,int f)
{
    int l = a[s].size();
    for(int i = 0; i < l; i++){
        int v = a[s][i];
        if(v == f) continue;
        h[v] = h[s] + 1;
        ans += h[v];
        dfs1(v,s);
        size[s] += size[v];
    }
    size[s] += 1;
}
  • 然后定义dp[s]表示以s为节点的深度和。假设v是u的孩子节点,那么dp[v] = dp[u] + n - 2*size[v],因为孩子节点v的子树上的节点到v的深度为到节点u的深度减一,其它节点深度加一,我们已知节点v的子树的小为size[v],每个节点深度减一,总共size[v]个节点,所以减去size[v],剩余其它节点为n-size[i],所以dp[v] = dp[v] - size[v]+n-size[v] = dp[u] + n - 2*size[v].再一遍dfs求。
void dfs2(int s,int f)
{
    ans = min(ans,dp[s]);
    int l = a[s].size();
    for(int i = 0; i < l; i++){
        int v = a[s][i];
        if(v == f) continue;
        dp[v] = dp[s] + n - 2*size[v];
        dfs2(v,s);
    //  ans = min(ans,)
    }
}

附上例题:https://ac.nowcoder.com/acm/contest/4479/C

Problem

求以1-n为根节点的总深度最小值。

Solution

利用换根dp,思路见上面解释。

Code

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <stack>
#include <queue>
#include <string.h>
#include <cmath>
#include <bitset> 
#include <set>
#include <map>
#include <list>
#define ull unsigned long long
#define ll long long
const int inf = 0x3f3f3f3f;
const int mod = 1e9+7;
const int N = 500005;
const ll ds = 1e15+7;
const double p1 = 3.141592653589793238462643383;
const ll res = 233;

using namespace std;

vector<int>a[1000005];
int size[1000005],h[1000005],n,u,v;
ll dp[1000005],ans = 0;
void dfs1(int s,int f)
{
	int l = a[s].size();
	for(int i = 0; i < l; i++){
		int v = a[s][i];
		if(v == f) continue;
		h[v] = h[s] + 1;
		ans += h[v];
		dfs1(v,s);
		size[s] += size[v];
	}
	size[s] += 1;
}

void dfs2(int s,int f)
{
	ans = min(ans,dp[s]);
	int l = a[s].size();
	for(int i = 0; i < l; i++){
		int v = a[s][i];
		if(v == f) continue;
		dp[v] = dp[s] + n - 2*size[v];
		dfs2(v,s);
	//	ans = min(ans,)
	}
}

int main()
{
	cin >> n;
	for(int i = 1; i < n; i++){
	    cin >> u >> v;
	    a[u].push_back(v);
	    a[v].push_back(u);
	}
	dfs1(1,-1);
	//cout << ans << endl;
	dp[1] = ans;
	dfs2(1,-1);
	cout << ans << endl;
//	for(int i = 1; i <= n; i++){
//		cout << h[i] << " ";
//	}
 	return 0;
}

 

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: PS176 DP-to-HDMI Dongle Reference是一种将DisplayPort信号转为HDMI信号的接口产品。DisplayPort和HDMI都是一种用于音视频传输的数字接口标准。DP-to-HDMI Dongle可以将使用DisplayPort接口的设备(如电脑、笔记本电脑、手机等)连接到使用HDMI接口的显示设备(如电视、投影仪等)上进行视频和音频输出。 PS176 DP-to-HDMI Dongle Reference采用了PS176芯片作为控制芯片,这是一款由Cypress(赛普拉斯)公司生产的高性能芯片,用于实现DisplayPort和HDMI之间的转。该芯片具有稳定的转效果和优质的信号传输能力,可以确保高清视频和高质量音频的传输。同时,该芯片还支持高达4K分辨率的视频输出,可以满足用户对高清画面的需求。 使用PS176 DP-to-HDMI Dongle Reference时,只需将DisplayPort接口插入设备的DisplayPort输出端口,然后将HDMI接口插入显示设备的HDMI输入端口,接口插拔简单方便。插上后,显示设备即可通过HDMI接口接收到DisplayPort信号,并将其转为对应的视频和音频信号进行输出,实现设备之间的连接与传输。 总结而言,PS176 DP-to-HDMI Dongle Reference是一款使用PS176芯片的DisplayPort转HDMI的转接头产品,适用于将使用DisplayPort接口的设备连接到使用HDMI接口的显示设备上进行视频和音频输出。它具有可靠的转效果、优质的信号传输能力和高分辨率的视频输出,能够满足用户对高清画面的需求。 ### 回答2: PS176 DP到HDMI转接器参考是一种数字信号转设备,用于将DisplayPort(DP)视频信号转为HDMI(High-Definition Multimedia Interface)信号。它可以连接支持DP输出的计算机或其他设备与使用HDMI输入的显示器、电视或投影仪等设备进行连接。 这款转接器采用了PS176芯片作为参考设计。PS176芯片是一种高性能的数字视频处理器,具有可靠稳定的信号转能力。它能够将DP的信号转为HDMI的信号,并且支持高分辨率的视频输出。使用这个转接器,用户可以将高品质的DP视频信号传输到HDMI设备上,实现高清晰度的视频显示。 该转接器参考设计还可能包括其他组件,例如电路板、接口、插头等,以提供完整的功能和兼容性。它可能支持高带宽的视频传输,包括4K、60Hz的高分辨率视频输出。除了视频信号的转,这个转接器也可以传输音频信号,使用户能够享受到高质量的音频效果。 对于使用PS176 DP到HDMI转接器参考设计的用户来说,他们只需要将转接器的DisplayPort接口连接到DP输出设备上,再将HDMI接口连接到HDMI输入设备上,就可以实现信号转和视频传输。这款转接器设计简单易用,适用于不同场合的应用,例如办公室、家庭娱乐、教育等。 总之,PS176 DP到HDMI转接器参考是一款高性能的数字信号转设备,基于PS176芯片设计,可以将DisplayPort信号转为HDMI信号,实现高清晰度的视频和音频传输,满足用户的不同需求。 ### 回答3: PS176 DP到HDMI转接头是一种用于连接DisplayPort(DP)接口和HDMI接口的转接头参考设计。DisplayPort和HDMI是两种常见的视频传输接口,DisplayPort主要用于连接电脑和显示器,而HDMI则广泛应用于电视、投影仪和一些消费电子设备。 PS176是一个高性能的转接头控制器,具有很多先进的特性。它支持DisplayPort 1.4a版本和HDMI 2.0b版本的规范,可以实现高清的视频传输和音频输出。该参考设计还支持高达4K分辨率的视频传输,保证了图像的清晰度和细节,同时还能够传输高品质的音频。 此外,PS176还具备一些其他特点,比如支持多种色彩空间和色深的传输,能够处理高帧率视频和3D视频,并支持多显示器环境。它还采用了先进的视频处理技术,如动态范围扩展、色彩空间转和降噪等,进一步提升了图像质量。 对于用户而言,使用PS176 DP到HDMI转接头可以方便地将DP接口的设备连接到HDMI接口的显示设备上,如连接笔记本电脑到电视或投影仪。这使得用户可以享受更大的屏幕空间和更高的分辨率,同时还能够通过一根线缆传输音频信号,消除了多余的接线和插拔。 总的来说,PS176 DP到HDMI转接头参考设计是一种可靠、高性能的解决方案,能够有效地连接DP和HDMI接口设备,提供高清的视频和音频传输。它为用户带来了更好的使用体验,扩展了设备的连接能力,适用于各种需求的场合。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值