洛谷P1270 “访问”美术馆(树上背包)

题目链接

https://www.luogu.com.cn/problem/P1270

思路

我们定义 d p [ i ] [ j ] dp[i][j] dp[i][j]表示当前节点为 i i i,且背包容量为 j j j秒时所能偷走的画的最大值。

在进行状态转移的时候,如果当前节点是叶子节点,就判断能取多少。如果是分叉路口,就枚举分别分配给左右子树的时间来进行转移。

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
typedef pair<int, int>pii;
const int N = 6e3 + 5, M = 1e6 + 5;
const int mod = 998244353;
int n, cnt;
int dp[N][N];//当前节点为i用掉j秒能偷到的画的数量的最大值
void dfs()
{
	int root = ++cnt, time, num;
	cin >> time >> num;
	time <<= 1;
	if (num)
	{
		for (int i = time; i <= n; i++)
		{
			dp[root][i] = min(num, (i - time) / 5);
		}
	}
	else
	{
		int left = cnt + 1;
		dfs();
		int right = cnt + 1;
		dfs();
		for (int i = time; i <= n; i++)
		{
			for (int lr = 0; lr <= i - time; lr++)
			{
				dp[root][i] = max(dp[root][i], dp[left][lr] + dp[right][i - time - lr]);
			}
		}
	}
}
void solve()
{
	cin >> n;
	n--;
	dfs();
	cout << dp[1][n] << endl;
}

signed main()
{
	ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);
	int test = 1;
	// cin >> test;
	for (int i = 1; i <= test; i++)
	{
		solve();
	}
	return 0;
}
相关推荐
草莓熊Lotso6 小时前
Linux 文件描述符与重定向实战:从原理到 minishell 实现
android·linux·运维·服务器·数据库·c++·人工智能
历程里程碑6 小时前
Linux22 文件系统
linux·运维·c语言·开发语言·数据结构·c++·算法
你撅嘴真丑13 小时前
第九章-数字三角形
算法
在路上看风景13 小时前
19. 成员初始化列表和初始化对象
c++
uesowys13 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
zmzb010313 小时前
C++课后习题训练记录Day98
开发语言·c++
ValhallaCoder13 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮13 小时前
AI 视觉连载1:像素
算法
念风零壹14 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
智驱力人工智能14 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算