【树形dp】K - Integers on a Tree AtCoder - arc063_c

探讨了一种使用树形动态规划(DP)解决树上节点点权问题的方法,要求相邻节点点权之差为1。通过判断奇偶性和计算每个节点的合法区间,可以确定是否存在解决方案并构造其一。
摘要由CSDN通过智能技术生成

题目https://vjudge.net/contest/411616#problem/K

题意:给出一个n个点,n-1条边的树,给定k个点的点权,判断是否有一种方法,将剩下n-k点填上点权,使得任意相邻的两个点点权之差为1,如果存在啧输出任意一种方案。

思路

  • 首先,差1可以得出相邻两点的奇偶性不同,因此我们只要根据这个条件判断合法性,并求出每个点的合法区间,就可以任意构造一组解。
  • 构造合法区间可以考虑树形dp求解,对于每个点来说,它的合法区间就是本身和所有儿子结点的交集,求出所有合法区间,就可以任意跑出一组解了。

代码

#include<bits/stdc++.h>
#define INF 0x3f3f3f3f
#define lowbit(x) x&(-x)
#define pb push_back
using namespace std;

typedef long long ll;
typedef pair<int,int>P;
typedef unsigned long long ull;
vector<int>G[100010];
int l[100010],r[100010],vis[100010],val[100010],rt,ans[100010];
bool dfs1(int x,int fa,int tmp)
{
   
    if(vis[x]&&tmp!=(val
读取PNG图片作为无符号16位整数通常涉及图像处理库,因为PNG格式本身是一个复杂的压缩格式,包含多种数据类型和压缩算法。在编程语言中,如Python,你可以使用Pillow(PIL的后继者)这样的库来读取PNG图片并将其像素值转换为16位无符号整数。以下是一个基本的步骤和代码示例: 1. 安装Pillow库(如果尚未安装): ``` pip install Pillow ``` 2. 使用Pillow打开PNG图片文件。 3. 遍历图片的像素,并将每个像素的值转换为16位无符号整数。 示例代码(以Python为例): ```python from PIL import Image import numpy as np # 打开PNG文件 png_image = Image.open("image.png") # 将图片转换为16位无符号整数数组 # 注意:Pillow默认读取为8位无符号整数,对于16位数据需要指定模式 if png_image.mode == 'I': # 假设图片是16位无符号整数格式 png_array = np.array(png_image, dtype=np.uint16) else: # 转换模式为16位整数格式,注意这可能会改变原始数据的表示 # 对于16位深度的PNG,需要确保图像在保存时是以16位模式保存的 png_image = png_image.convert('I') png_array = np.array(png_image, dtype=np.uint16) # 现在png_array包含了图片数据,作为16位无符号整数 ``` 注意,上述代码假设PNG图片是以16位模式保存的。如果PNG图片不是以16位模式保存,上述代码将会将8位数据错误地当作16位来处理,这可能会导致数据不准确。确保图片的保存格式与你读取它的格式相匹配是很重要的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值