[Algorithm][综合训练][kotori和气球][体操队形][二叉树中的最大路径和]详细讲解

本文主要是介绍[Algorithm][综合训练][kotori和气球][体操队形][二叉树中的最大路径和]详细讲解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 1.kotori和气球
    • 1.题目链接
    • 2.算法原理详解 && 代码实现
  • 2.体操队形
    • 1.题目链接
    • 2.算法原理详解 && 代码实现
  • 3.二叉树中的最大路径和
    • 1.题目链接
    • 2.算法原理详解 && 代码实现


1.kotori和气球

1.题目链接

  • kotori和气球

2.算法原理详解 && 代码实现

  • 解法:数学 – 排列组合问题 --> n ∗ ( n − 1 ) m − 1 n * (n - 1)^{m - 1} n(n1)m1
    #include <iostream>
    using namespace std;int main()
    {const int MOD = 109;int n = 0, m = 0;cin >> n >> m;int ret = n;for(int i = 0; i < m - 1; i++){ret = ret * (n - 1) % MOD;}cout << ret << endl;return 0;
    }
    

2.体操队形

1.题目链接

  • 体操队形

2.算法原理详解 && 代码实现

  • 解法:DFS + 枚举 --> 重点是画出决策树
    #include <iostream>
    #include <vector>
    using namespace std;int n = 0, ret = 0;
    vector<int> nums;
    vector<bool> visit;void DFS(int pos)
    {if(pos == n + 1){ret++;return;}// 对于该位置,依次枚举每个队员for(int i = 1; i <= n; i++){if(visit[i]) // 剪枝 -> i队员已经被放过{continue;}if(visit[nums[i]]) // 剪枝 -> i队员的诉求已经无法完成{return;}visit[i] = true; // 放上i号队员DFS(pos + 1);visit[i] = false; // 回溯}
    }int main()
    {cin >> n;nums.resize(n + 1, 0);visit.resize(n + 1, false);for(int i = 1; i <= n; i++){cin >> nums[i];}DFS(1); // 按进入位置划分cout << ret << endl;return 0;
    }
    

3.二叉树中的最大路径和

1.题目链接

  • 二叉树中的最大路径和

2.算法原理详解 && 代码实现

  • 解法:DFS + 树形DP(后序遍历)
    • 在某棵子树上整理什么信息:经过根节点的最大路径和
      • ret = max(root->val + l + r, ret)
    • 左子树提供:以左子树为根的最大单链和
      • l = max(0, l)
    • 右子树提供:以右子树为根的最大单链和
      • r = max(0, r)
    • 返回值:以自己为根的最大单链和
      • return root->val + max(l, r);
    class Solution
    {
    public:int ret = -0x3f3f3f3f;int maxPathSum(TreeNode* root) {DFS(root);return ret;}int DFS(TreeNode* root){if(root == nullptr){return 0;}// 左右子树最大单链和int l = max(0, DFS(root->left));int r = max(0, DFS(root->right));ret = max(ret, root->val + l + r); // 经过root的最⼤路径和return root->val + max(l, r);}
    };
    

这篇关于[Algorithm][综合训练][kotori和气球][体操队形][二叉树中的最大路径和]详细讲解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C# WinForms存储过程操作数据库的实例讲解

《C#WinForms存储过程操作数据库的实例讲解》:本文主要介绍C#WinForms存储过程操作数据库的实例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、存储过程基础二、C# 调用流程1. 数据库连接配置2. 执行存储过程(增删改)3. 查询数据三、事务处

Java使用Curator进行ZooKeeper操作的详细教程

《Java使用Curator进行ZooKeeper操作的详细教程》ApacheCurator是一个基于ZooKeeper的Java客户端库,它极大地简化了使用ZooKeeper的开发工作,在分布式系统... 目录1、简述2、核心功能2.1 CuratorFramework2.2 Recipes3、示例实践3

通过Docker Compose部署MySQL的详细教程

《通过DockerCompose部署MySQL的详细教程》DockerCompose作为Docker官方的容器编排工具,为MySQL数据库部署带来了显著优势,下面小编就来为大家详细介绍一... 目录一、docker Compose 部署 mysql 的优势二、环境准备与基础配置2.1 项目目录结构2.2 基

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux系统中配置静态IP地址的详细步骤

《Linux系统中配置静态IP地址的详细步骤》本文详细介绍了在Linux系统中配置静态IP地址的五个步骤,包括打开终端、编辑网络配置文件、配置IP地址、保存并重启网络服务,这对于系统管理员和新手都极具... 目录步骤一:打开终端步骤二:编辑网络配置文件步骤三:配置静态IP地址步骤四:保存并关闭文件步骤五:重

Centos环境下Tomcat虚拟主机配置详细教程

《Centos环境下Tomcat虚拟主机配置详细教程》这篇文章主要讲的是在CentOS系统上,如何一步步配置Tomcat的虚拟主机,内容很简单,从目录准备到配置文件修改,再到重启和测试,手把手带你搞定... 目录1. 准备虚拟主机的目录和内容创建目录添加测试文件2. 修改 Tomcat 的 server.X

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

Spring Boot拦截器Interceptor与过滤器Filter详细教程(示例详解)

《SpringBoot拦截器Interceptor与过滤器Filter详细教程(示例详解)》本文详细介绍了SpringBoot中的拦截器(Interceptor)和过滤器(Filter),包括它们的... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)详细教程1. 概述1

使用Dify访问mysql数据库详细代码示例

《使用Dify访问mysql数据库详细代码示例》:本文主要介绍使用Dify访问mysql数据库的相关资料,并详细讲解了如何在本地搭建数据库访问服务,使用ngrok暴露到公网,并创建知识库、数据库访... 1、在本地搭建数据库访问的服务,并使用ngrok暴露到公网。#sql_tools.pyfrom

Windows系统下如何查找JDK的安装路径

《Windows系统下如何查找JDK的安装路径》:本文主要介绍Windows系统下如何查找JDK的安装路径,文中介绍了三种方法,分别是通过命令行检查、使用verbose选项查找jre目录、以及查看... 目录一、确认是否安装了JDK二、查找路径三、另外一种方式如果很久之前安装了JDK,或者在别人的电脑上,想