hihocoder#1055 : 刷油漆 算法详解以及java源码实现

2024-04-10 18:08

本文主要是介绍hihocoder#1055 : 刷油漆 算法详解以及java源码实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原题地址详见:http://hihocoder.com/problemset/problem/1055?sid=869767

题目分析:简而言之,就是获得一棵树如果涂连续节点,节点数目一定,最终获得的最大值是多少。

思路:

dp[u][j]表示以节点u为根的大小为 j 的树可得到的最大分数,答案就是dp[1][m]。

状态转移方程为:dp[u][j]=max(dp[v1][k1]+dp[v2][k2]+...+dp[vx][kx]),v是u的子节点。


注意点:

1.边是单向的还是双向的:因为要求是从1开始,我们可以把树设置为单向边,按照节点从大向小的顺序,避免重复遍历,陷入死循环。还有一种递归是根据边来递归的,参考http://www.cnblogs.com/easonliu/p/4468799.html
2.M是正向还是反向遍历?考虑到我们背包问题,物品不可重复使用,类似于这里的节点不可重复使用,我们采用的是用上一状态更新当前状态,而不是更新后的状态更新当前状态,所以选择反向遍历。

源代码如下:
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;public class CrushRoller {public static void main(String args[]){Scanner in=new Scanner(System.in);while(in.hasNextInt()){int N=in.nextInt();int M=in.nextInt();//存储每个节点的价值int[] V=new int[N+1];//dp[i][j]表示存储i节点为根的时候,涂上M个子节点的最大价值int[][] dp=new int[N+1][M+1];//存储单向边List<List<Integer>> map=new ArrayList<List<Integer>>();map.add(new ArrayList<Integer>());for(int i=1;i<=N;i++){V[i]=in.nextInt();map.add(new ArrayList<Integer>());dp[i][1]=V[i];}for(int i=1;i<N;i++){int a=in.nextInt();int b=in.nextInt();map.get(a).add(b);}dfs(dp,1,M,map);System.out.println(dp[1][M]);}in.close();}public static void dfs(int[][] dp,int node,int M,List<List<Integer>> map){List<Integer> children=map.get(node);//递归调用子树获得子树的dpfor(int child:children){//获得以当前为根的子树的最大dpdfs(dp,child,M-1,map);//类似背包问题从大到小for(int i=M;i>1;i--){for(int j=1;j<i;j++){dp[node][i]=Math.max(dp[node][i],dp[node][i-j]+dp[child][j]);}}}}
}


这篇关于hihocoder#1055 : 刷油漆 算法详解以及java源码实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/891773

相关文章

Nginx更新SSL证书的实现步骤

《Nginx更新SSL证书的实现步骤》本文主要介绍了Nginx更新SSL证书的实现步骤,包括下载新证书、备份旧证书、配置新证书、验证配置及遇到问题时的解决方法,感兴趣的了解一下... 目录1 下载最新的SSL证书文件2 备份旧的SSL证书文件3 配置新证书4 验证配置5 遇到的http://www.cppc

Nginx之https证书配置实现

《Nginx之https证书配置实现》本文主要介绍了Nginx之https证书配置的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起... 目录背景介绍为什么不能部署在 IIS 或 NAT 设备上?具体实现证书获取nginx配置扩展结果验证

Java利用Spire.XLS for Java自动化设置Excel的文档属性

《Java利用Spire.XLSforJava自动化设置Excel的文档属性》一个专业的Excel文件,其文档属性往往能大大提升文件的可管理性和可检索性,下面我们就来看看Java如何使用Spire... 目录Spire.XLS for Java 库介绍与安装Java 设置内置的 Excel 文档属性Java

Java中的CompletableFuture核心用法和常见场景

《Java中的CompletableFuture核心用法和常见场景》CompletableFuture是Java8引入的强大的异步编程工具,支持链式异步编程、组合、异常处理和回调,介绍其核心用法,通过... 目录1、引言2. 基本概念3. 创建 CompletableFuture3.1. 手动创建3.2.

java中4种API参数传递方式统一说明

《java中4种API参数传递方式统一说明》在Java中,我们可以使用不同的方式来传递参数给方法或函数,:本文主要介绍java中4种API参数传递方式的相关资料,文中通过代码介绍的非常详细,需要的... 目录1. 概述2. 参数传递方式分类2.1 Query Parameters(查询参数)2.2 Path

SpringBoot整合 Quartz实现定时推送实战指南

《SpringBoot整合Quartz实现定时推送实战指南》文章介绍了SpringBoot中使用Quartz动态定时任务和任务持久化实现多条不确定结束时间并提前N分钟推送的方案,本文结合实例代码给大... 目录前言一、Quartz 是什么?1、核心定位:解决什么问题?2、Quartz 核心组件二、使用步骤1

Java线程池核心参数原理及使用指南

《Java线程池核心参数原理及使用指南》本文详细介绍了Java线程池的基本概念、核心类、核心参数、工作原理、常见类型以及最佳实践,通过理解每个参数的含义和工作原理,可以更好地配置线程池,提高系统性能,... 目录一、线程池概述1.1 什么是线程池1.2 线程池的优势二、线程池核心类三、ThreadPoolE

使用Redis实现会话管理的示例代码

《使用Redis实现会话管理的示例代码》文章介绍了如何使用Redis实现会话管理,包括会话的创建、读取、更新和删除操作,通过设置会话超时时间并重置,可以确保会话在用户持续活动期间不会过期,此外,展示了... 目录1. 会话管理的基本概念2. 使用Redis实现会话管理2.1 引入依赖2.2 会话管理基本操作

Springboot请求和响应相关注解及使用场景分析

《Springboot请求和响应相关注解及使用场景分析》本文介绍了SpringBoot中用于处理HTTP请求和构建HTTP响应的常用注解,包括@RequestMapping、@RequestParam... 目录1. 请求处理注解@RequestMapping@GetMapping, @PostMappin

Java调用DeepSeek API的8个高频坑与解决方法

《Java调用DeepSeekAPI的8个高频坑与解决方法》现在大模型开发特别火,DeepSeek因为中文理解好、反应快、还便宜,不少Java开发者都用它,本文整理了最常踩的8个坑,希望对... 目录引言一、坑 1:Token 过期未处理,鉴权异常引发服务中断问题本质典型错误代码解决方案:实现 Token