当前位置: 首页 > article >正文

洛谷 P2015:二叉苹果树 ← 有依赖的背包问题

【题目来源】https://www.luogu.com.cn/problem/P2015【题目描述】有一棵苹果树如果树枝有分叉一定是分二叉就是说没有只有一个儿子的结点。这棵树共有 N 个结点叶子点或者树枝分叉点编号为 1∼N树根编号一定是 1。我们用一根树枝两端连接的结点的编号来描述一根树枝的位置。下面是一颗有 4 个树枝的树2 5 \ / 3 4 \ / 1现在这颗树枝条太多了需要剪枝。但是一些树枝上长有苹果。给定需要保留的树枝数量求出最多能留住多少苹果。留住一个苹果的定义为苹果所在枝条直接与根相连或通过其他枝条间接与根相连。【输入格式】第一行 2 个整数 N 和 Q分别表示表示树的结点数和要保留的树枝数量。接下来 N−1 行每行 3 个整数描述一根树枝的信息前 2 个数是它连接的结点的编号第 3 个数是这根树枝上苹果的数量。【输出格式】一个数最多能留住的苹果的数量。【输入样例】5 21 3 11 4 102 3 203 5 20【输出样例】21【数据范围】1⩽QN⩽100每根树枝上的苹果 ⩽3×10^4。【算法分析】● 有依赖的背包树形背包核心是物品间存在选子必选父的单向依赖关系依赖结构通常为森林或多叉树主流解法为树形 DP 结合分组背包自底向上合并若题目中是双向强依赖、互相绑定的物品组选其一必全选则可先用并查集将连通块缩为超级物品再套用普通 01 背包求解两种思路对应不同依赖模型共同构成完整解法体系。● 有依赖的背包 / 树形背包 选儿子必须先选爹 把每个子树当成一组物品● 邻接表https://blog.csdn.net/hnjzsyjyj/article/details/155789364● 核心代码解析1f[u][k] 表示在以 u 为根的子树中保留 k 根树枝能得到的最大苹果数。2f[u][j]max(f[u][j],f[u][j-i-1]f[v][i]w) 中j-i-1 表示留给自己其他子树的树枝。-1 表示必须保留 u-v 这一条树枝。【算法代码】#include bits/stdc.h using namespace std; const int N105; vectorpairint,int g[N]; int f[N][N]; int n,V; void dfs(int u,int fa) { for(auto t:g[u]) { int vt.first; int wt.second; if(vfa) continue; dfs(v,u); for(int jV; j1; j--) { for(int i0; ij; i) { f[u][j]max(f[u][j],f[u][j-i-1]f[v][i]w); } } } } int main() { memset(f,0,sizeof f); cinnV; for(int i1; in; i) { int x,y,cnt; cinxycnt; g[x].push_back({y,cnt}); g[y].push_back({x,cnt}); } dfs(1,-1); coutf[1][V]endl; return 0; } /* in: 5 2 1 3 1 1 4 10 2 3 20 3 5 20 out: 21 */【参考文献】https://blog.csdn.net/hnjzsyjyj/article/details/159791882https://blog.csdn.net/hnjzsyjyj/article/details/159616887https://blog.csdn.net/hnjzsyjyj/article/details/159650172

相关文章:

洛谷 P2015:二叉苹果树 ← 有依赖的背包问题

【题目来源】 https://www.luogu.com.cn/problem/P2015 【题目描述】 有一棵苹果树,如果树枝有分叉,一定是分二叉(就是说没有只有一个儿子的结点)。 这棵树共有 N 个结点(叶子点或者树枝分叉点)&#xff0…...

图卷积神经网络安全最佳实践:7大关键漏洞防范与代码审计终极指南 [特殊字符]️

图卷积神经网络安全最佳实践:7大关键漏洞防范与代码审计终极指南 🛡️ 【免费下载链接】pygcn Graph Convolutional Networks in PyTorch 项目地址: https://gitcode.com/gh_mirrors/py/pygcn 图卷积神经网络(GCN)作为处理…...

终极指南:10个技巧快速解决iOS符号拦截失败问题

终极指南:10个技巧快速解决iOS符号拦截失败问题 【免费下载链接】fishhook A library that enables dynamically rebinding symbols in Mach-O binaries running on iOS. 项目地址: https://gitcode.com/gh_mirrors/fi/fishhook 如果你在使用fishhook进行iOS…...

Spring Data测试终极指南:Testcontainers集成测试与Mock数据策略详解

Spring Data测试终极指南:Testcontainers集成测试与Mock数据策略详解 【免费下载链接】spring-data-examples Spring Data Example Projects 项目地址: https://gitcode.com/gh_mirrors/sp/spring-data-examples Spring Data测试是确保数据访问层可靠性的关键…...

终极指南:如何为Alignment Handbook项目做出技术贡献

终极指南:如何为Alignment Handbook项目做出技术贡献 【免费下载链接】alignment-handbook Robust recipes to align language models with human and AI preferences 项目地址: https://gitcode.com/gh_mirrors/al/alignment-handbook Alignment Handbook 是…...

终极指南:如何自定义Android RecyclerView ItemAnimator动画扩展

终极指南:如何自定义Android RecyclerView ItemAnimator动画扩展 【免费下载链接】android-advancedrecyclerview RecyclerView extension library which provides advanced features. (ex. Googles Inbox app like swiping, Play Music app like drag and drop sor…...

Agent在财务场景有哪些核心应用?深度解析2026企业智能化转型路径

站在2026年的技术节点回望,财务部门早已从传统的“记账中心”转型为企业的“战略决策大脑”。AI Agent(人工智能助手/智能体)的爆发式应用,彻底终结了繁琐的表单时代。与2024年的实验性尝试不同,当下的财务Agent具备了…...

Elasticsearch-PHP聚合分析终极指南:7步掌握数据统计与可视化

Elasticsearch-PHP聚合分析终极指南:7步掌握数据统计与可视化 【免费下载链接】elasticsearch-php Official PHP client for Elasticsearch. 项目地址: https://gitcode.com/gh_mirrors/el/elasticsearch-php Elasticsearch-PHP是官方PHP客户端,提…...

制造业上线Agent,能获得哪些核心价值?——2026工业AI从“辅助决策”迈向“全自主执行”的深度解析

站在2026年这个时间节点回望,制造业的数字化转型已完成了从“数据上云”到“智能入链”的惊人跨越。如果说过去十年的工业互联网核心是解决“连接”问题,那么2026年全面爆发的AI Agent(智能体)则彻底解决了“执行”问题。在当前的…...

RefluxJS终极部署指南:从开发到生产的完整工作流程

RefluxJS终极部署指南:从开发到生产的完整工作流程 【免费下载链接】refluxjs A simple library for uni-directional dataflow application architecture with React extensions inspired by Flux 项目地址: https://gitcode.com/gh_mirrors/re/refluxjs Re…...

批量图片添加文字水印工具:Windows 上手指南(预览与平铺)

面向需要在 Windows 上 批量 给 图片 叠 文字水印 的同事,工具名【批量图片添加文字水印工具】。下文只写能力与操作顺序,不写实现细节。输入与目录支持选择多个文件或整个文件夹,路径可拖拽填入;多文件路径用分号分隔。勾选「遍历…...

批量图片添加随机边框工具:Windows 操作指南与场景说明

本文介绍如何在 Windows 桌面上批量为图片加边框,并重点说明「随机边框」模式与固定样式模式的差异。工具名称:【批量图片添加随机边框】。适用场景电商、社群物料需要统一「有框」观感,但不希望每张边框完全一样。文件夹内大量 JPG、PNG、GI…...

终极指南:使用Docker快速部署WriteGPT AI创作平台

终极指南:使用Docker快速部署WriteGPT AI创作平台 【免费下载链接】WriteGPT 基于开源GPT2.0的初代创作型人工智能 | 可扩展、可进化 项目地址: https://gitcode.com/gh_mirrors/wri/WriteGPT WriteGPT是一款基于开源GPT-2.0的初代创作型人工智能框架&#x…...

打造专业视频编辑App时间线:基于android-advancedrecyclerview的终极拖拽实现指南

打造专业视频编辑App时间线:基于android-advancedrecyclerview的终极拖拽实现指南 【免费下载链接】android-advancedrecyclerview RecyclerView extension library which provides advanced features. (ex. Googles Inbox app like swiping, Play Music app like d…...

终极指南:Linkerd与Rancher集成的完整实践方案

终极指南:Linkerd与Rancher集成的完整实践方案 【免费下载链接】linkerd Old repo for Linkerd 1.x. See the linkerd2 repo for Linkerd 2.x. 项目地址: https://gitcode.com/gh_mirrors/li/linkerd Linkerd作为一款强大的服务网格工具,与Ranche…...

考研408计算机学科专业基础综合——计算机网络复习

考研408计算机学科专业基础综合 计算机网络复习 核心说明:本笔记聚焦考研408计算机网络高频考点、必背知识点,贴合命题规律(选择题为主、大题集中在核心协议),剔除冗余内容,突出重难点,适配冲刺…...

考研408计算机学科专业基础——计算机组成原理复习

考研408计算机学科专业基础——计算机组成原理复习 核心说明:本笔记聚焦考研408计算机组成原理(计组)高频考点、必背知识点,贴合命题规律(选择大题),剔除冗余内容,突出重难点&#x…...

考研408计算机学科专业基础综合 数据结构复习

考研408计算机学科专业基础综合 数据结构复习 第一页:数据结构(一)——基础线性表(高频) 一、数据结构核心基础(必背) 1. 数据结构定义:相互之间存在一种或多种特定关系的数据元素的…...

高效部署Kafka Connect集群:AKHQ的5个进阶实战策略

高效部署Kafka Connect集群:AKHQ的5个进阶实战策略 【免费下载链接】akhq Kafka GUI for Apache Kafka to manage topics, topics data, consumers group, schema registry, connect and more... 项目地址: https://gitcode.com/gh_mirrors/ak/akhq Apache K…...

国家中小学智慧教育平台电子课本PDF下载工具:教育资源的智能获取方案

国家中小学智慧教育平台电子课本PDF下载工具:教育资源的智能获取方案 【免费下载链接】tchMaterial-parser 国家中小学智慧教育平台 电子课本下载工具,帮助您从智慧教育平台中获取电子课本的 PDF 文件网址并进行下载,让您更方便地获取课本内容…...

终极性能调优指南:如何配置dnstwist实现超高速域名扫描

终极性能调优指南:如何配置dnstwist实现超高速域名扫描 【免费下载链接】dnstwist Domain name permutation engine for detecting homograph phishing attacks, typo squatting, and brand impersonation 项目地址: https://gitcode.com/gh_mirrors/dn/dnstwist …...

5个实用技巧:掌握FastBle日志系统的完整调试指南

5个实用技巧:掌握FastBle日志系统的完整调试指南 【免费下载链接】FastBle Android Bluetooth Low Energy (BLE) Fast Development Framework. It uses simple ways to filter, scan, connect, read ,write, notify, readRssi, setMTU, and multiConnection. 项目…...

具备“看屏幕”能力的Agent能解决哪些传统接口无法解决的问题?实在Agent以ISSUT视觉感知构建企业级AI智能体新高度

2026年4月,人工智能领域正经历从“文本对话”向“具身操作”的范式跨越。根据腾讯云在2026年3月27日发布的《Agent全景产品图谱》,具备“看屏幕”能力的视觉智能体已成为破除数字化转型“最后一步”僵局的核心变量。在过去的一周内,清华大学与…...

终极TypeScript类型安全指南:LiveTerm接口定义与类型检查最佳实践

终极TypeScript类型安全指南:LiveTerm接口定义与类型检查最佳实践 【免费下载链接】LiveTerm 💻 Build terminal styled websites in minutes! 项目地址: https://gitcode.com/gh_mirrors/li/LiveTerm LiveTerm是一个基于Next.js的终端风格网站构…...

终极指南:如何使用dnstwist与模糊哈希精准识别钓鱼网站攻击

终极指南:如何使用dnstwist与模糊哈希精准识别钓鱼网站攻击 【免费下载链接】dnstwist Domain name permutation engine for detecting homograph phishing attacks, typo squatting, and brand impersonation 项目地址: https://gitcode.com/gh_mirrors/dn/dnstw…...

Tealdeer终极指南:5分钟掌握命令行工具的快速使用技巧

Tealdeer终极指南:5分钟掌握命令行工具的快速使用技巧 【免费下载链接】tealdeer A very fast implementation of tldr in Rust. 项目地址: https://gitcode.com/gh_mirrors/te/tealdeer Tealdeer是一个基于Rust语言开发的极速tldr客户端实现,为命…...

Linux网络诊断工具ping、traceroute等命令实战指南

在Linux系统的网络世界里,网络诊断工具就像是我们手中的“听诊器”,能够帮助我们精准地找出网络中存在的问题。今天,我们就来深入了解ping、traceroute等网络诊断命令的使用,通过实际操作和示例,让你轻松掌握使用这些工…...

milkup:桌面端 markdown AI续写和即时渲染

一、项目背景与需求分析1.1 milkup 项目简介milkup 是一个现代化的桌面端 Markdown 编辑器,基于 Electron Vue 3 TypeScript 构建。项目的核心目标是提供一个功能强大、体验优雅、性能出色的 Markdown 编辑环境。核心技术栈:前端框架:Vue 3…...

Shell脚本进程锁机制解析

1. 命令行参数解析 (第9-21行)12345while getopts "m:o:r:" arg; docase $arg in# ... 参数处理逻辑(代码中省略了具体内容)esacdone使用 getopts 解析命令行参数支持三个带参数的选项:-m、-o、-r具体处理逻辑在代码中被省略了2. 文…...

FastBle单元测试终极指南:Mockito在Android蓝牙BLE开发中的7个实战技巧

FastBle单元测试终极指南:Mockito在Android蓝牙BLE开发中的7个实战技巧 【免费下载链接】FastBle Android Bluetooth Low Energy (BLE) Fast Development Framework. It uses simple ways to filter, scan, connect, read ,write, notify, readRssi, setMTU, and mu…...