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

swoole做网站公众号做微网站吗

swoole做网站,公众号做微网站吗,网站有哪些平台,建设银行青海省分行门户网站文章目录 树形DP讲解一、引言二、树形DP基础1、树的定义2、树形DP的基本思想3、代码示例#xff1a;子树大小 三、经典例题解析1、树的平衡点1.1、代码示例 2、没有上司的舞会#xff08;树的最大独立集#xff09;2.1、代码示例 四、总结 树形DP讲解 一、引言 树形动态规… 文章目录 树形DP讲解一、引言二、树形DP基础1、树的定义2、树形DP的基本思想3、代码示例子树大小 三、经典例题解析1、树的平衡点1.1、代码示例 2、没有上司的舞会树的最大独立集2.1、代码示例 四、总结 树形DP讲解 一、引言 树形动态规划Tree DP是动态规划中的一种特殊形式它专门用于解决与树结构相关的问题。树形DP的核心思想是利用树的分形结构递归地定义和解决问题。在这篇文章中我们将深入探讨树形DP的基本概念、经典例题以及实际应用。 二、树形DP基础 1、树的定义 在图论中树被定义为一个连通且无圈的图。树的分形结构意味着树的每个子树也是一棵完整的树这使得树形DP天然适合递归求解。 2、树形DP的基本思想 树形DP通常遵循“先子树后合并”的原则这与树的后序遍历相似。我们先递归访问所有子树然后在根节点上合并结果。 3、代码示例子树大小 void dfs(int u) {if (u 是叶子) {f[u] 1;return;}for (int v : e[u]) {dfs(v);f[u] f[v];}f[u] 1; // 本身 }这段代码通过深度优先搜索DFS计算以每个节点为根的子树大小。 三、经典例题解析 1、树的平衡点 平衡点是指删除树中的某个节点后使得剩下的连通块中最大的连通块大小最小。我们可以通过计算每个节点的子树大小来找到平衡点。 1.1、代码示例 import java.util.ArrayList; import java.util.List;public class Main {static final int N 100010; // 假设N是图的最大节点数static ListInteger[] e new ArrayList[N];static int ans, idx, f[] new int[N];public static void main(String[] args) {// 初始化邻接表for (int i 0; i N; i) {e[i] new ArrayList();}// 示例调用int root 1; // 假设1是树的根节点int fa 0; // 根节点没有父节点dfs(root, fa);System.out.println(最大值: ans , 节点: idx);}static void dfs(int u, int fa) {f[u] 1;int mx 0;for (int v : e[u]) {if (v fa) continue;dfs(v, u);f[u] f[v];mx Math.max(mx, f[v]);}mx Math.max(mx, n - f[u]);if (ans mx) {ans mx;idx u;}}// 假设n是节点总数static int n 10; // 这里需要根据实际情况设置 }2、没有上司的舞会树的最大独立集 在这个问题中我们需要找到树的最大权值独立集即没有直接上司和下属关系的节点集合。 2.1、代码示例 import java.util.ArrayList; import java.util.Scanner;public class Main {static final int N 10000 10;static ArrayListInteger[] tr new ArrayList[N];static int[][] f new int[N][2];static int[] v new int[N];static int[] Happy new int[N];static int n;public static void main(String[] args) {Scanner scanner new Scanner(System.in);// 初始化邻接表for (int i 0; i N; i) {tr[i] new ArrayList();}n scanner.nextInt();for (int i 1; i n; i) {Happy[i] scanner.nextInt();}for (int i 1; i n; i) {int x scanner.nextInt();int y scanner.nextInt();tr[y].add(x);}int root 0;for (int i 1; i n; i) {if (v[i] 0) {root i;break;}}dfs(root);System.out.println(Math.max(f[root][0], f[root][1]));}static void dfs(int u) {f[u][0] 0;f[u][1] Happy[u];for (int v : tr[u]) {dfs(v);f[u][0] Math.max(f[v][0], f[v][1]);f[u][1] f[v][0];}} }四、总结 树形DP是一种强大的算法工具它通过利用树的结构特性来解决复杂的优化问题。通过本文的介绍和代码示例我们可以看到树形DP在解决树相关问题时的效率和优雅。掌握树形DP不仅能够提升算法设计能力还能在实际问题中找到创新的解决方案。 版权声明本博客内容为原创转载请保留原文链接及作者信息。 参考文章 【动态规划】树形DP完全详解 - RioTian - 博客园
http://www.hkea.cn/news/14277618/

相关文章:

  • 建筑网站图片godaddy wordpress迁移
  • PPT做音乐网站介绍网站开发都用什么数据库
  • 甘肃做网站多少钱wordpress图片备用地址
  • 网页制作企业网站作业网上设计接单的网站
  • 建设网站联盟c2c网站有哪些
  • 芜湖网站建设优化库尔勒谁在做电商网站建设
  • 河南网站建设推广公司荣成网站建设
  • 易网官方网站南通门户网站建设
  • 南京市建设工程网站南宁定制网站建设
  • 平阳县住房和城乡规划建设局网站如何用网站做淘宝客
  • 洞泾做网站公司网站pv是什么
  • 360免费建站 服务期班级网页模板
  • 哪里有门户网站开发.net 开源 企业网站
  • 江苏住房和城乡建设网站做网站用哪个开发工具好
  • 简述企业网站如何推广wordpress采集功能
  • 网站icp没有备案怎么检查六安人论坛最新招聘
  • 网上服务旗舰店东昌府聊城网站优化
  • 网站建设的基本内容外贸模版网站
  • icp备案后要建网站吗正规网站有哪些
  • 自适应型网站建设服务电话折腾wordpress
  • WordPress网站接入公众号杭州优化公司哪家好
  • 网站开发用户需求说明书定西网站建设公司排名照片
  • 基于jsp的网站开发的文献做网站的学什么代码
  • 佛山做网站3000开o2o网站需要什么手续
  • 福田网站建设费用网站建设 用什么语言
  • 提交网站入口企业网上申报入口
  • 中小型企业建设网站网站用户体验解决方案
  • 宁波北仑做网站酒店网站免费建设
  • 黑龙江期刊网站制作seo 专业为网站建设
  • 甜品网站模板如何做一起好的视频宣传自己的网站