代码随想录算法训练营第36期DAY43

2024-05-29 17:44

本文主要是介绍代码随想录算法训练营第36期DAY43,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

DAY43

343整数拆分

注意:当几个数的数值相近,乘积才会尽可能地大(好想:数一大一小,最大当然是自己乘以自己)

代码随想录官方题解:

  1. class Solution {
  2. public:
  3.     int integerBreak(int n) {
  4.     vector<intdp(n+1);
  5.     dp[0]=0,dp[1]=0;
  6.     dp[2]=1;
  7.     //求DP[i]
  8.     for(int i=3;i<=n;i++){
  9.         for(int j=1;j<=i/2;j++)
  10.         //i-1因为dp[0]没有意义
  11.         {
  12.             dp[i]=max(dp[i],max(j*(i-j),j*dp[i-j]));
  13.         }
  14.     }
  15.     return dp[n];
  16.     }
  17. };

力扣优质题解_Krahets:

太厉害了,数学方法:

  1. class Solution {
  2. public:
  3.     long long poww(int n,int index){
  4.         long long result=1;
  5.         while(index--) result*=n;
  6.         return result;
  7.     }
  8.     int integerBreak(int n) {
  9.     if(n<=3return n-1;
  10.     int mod=n%3,res=n/3;
  11.     if(mod==0return poww(3,res);
  12.     else if(mod==2return 2*poww(3,res);
  13.     else return 4*pow(3,res-1);
  14.     }
  15. };

力扣官方题解

这句话很好:由于每个正整数对应的最大乘积取决于比它小的正整数对应的最大乘积,因此可以使用动态规划来求解。这样DP动机就很可信了。

96不同的二叉搜索树

做完之后,完整地学习了卡特兰数。

  1. class Solution {
  2. public:
  3.     int numTrees(int n) {
  4.         vector<intdp(n+1);
  5.         dp[0]=1;
  6.         dp[1]=1;
  7.         for(int i=2;i<=n;i++){
  8.             for(int j=1;j<=i;j++)
  9.             dp[i]+=dp[j-1]*dp[i-j];
  10.         }
  11.         return dp[n];
  12.     }
  13. };

  1. class Solution {
  2. public:
  3.     int numTrees(int n) {
  4.         //C0=1;
  5.         long long C=1;
  6.         for(int i=0;i<n;i++){
  7.             C=C*2*(2*i+1)/(i+2);
  8.         }
  9.         return (int) C;
  10.     }
  11. };

卡特兰数学习

公式:

手写运算用:

编程解题用:

对应代码:

  1. class Solution {
  2. public:
  3.     int numTrees(int n) {
  4.         //C0=1;
  5.         long long C=1;
  6.         for(int i=0;i<n;i++){
  7.             C=C*2*(2*i+1)/(i+2);
  8.         }
  9.         return (int) C;
  10.     }
  11. };

参考资料:

  1. 《A First Course in Discrete Mathematics》
  2. 算法学习笔记(11):[卡特兰数 (Catalan)](https://zhuanlan.zhihu.com/p/609104268)
  3. Leetcode官方题解——96.不同的二叉搜索树

(https://leetcode.cn/problems/unique-binary-search-trees/solutions/329807/bu-tong-de-er-cha-sou-suo-shu-by-leetcode-solution/)

  1. Up-Right问题

简单 2n选n。

  1. Up-Right问题——不抵达对角线上方

真正引出了卡特兰数,具体分析及推导见《A First Course in Discrete Mathematics》

  1. Cn 表示2n长的序列,有n个0(right),n个1(up),在任意n(each stage),1的数量不超过0的数量。
  2. 由n对 左 右 括号构成的合法的括号序列数。

其实和3一样了。就是右括号数永远不超过左括号数。

  1. 一个栈(无穷大)的进栈顺序1,2,...,n有多少个不同的出栈顺序?

只要有进栈,就产生一个左括号;只要有出栈,就产生一个右括号。(2n长的序列)

那么每阶段右括号数量不超过左括号数量。卡特兰数

  1. N个节点可以构造出多少个不同的二叉树?

直接看图:

  1. 对角线不相交的情况下,将一个凸多边形区域分成三角形区域的方法数?

课本上也有,

看图:

  1. N个 +1 和 -1 构成2N项a1,a2,...,an,其任意前缀和a1+a2+..+ak非负 的序列数量个数。

-1别超过1就行了。

  1. 在圆上选择2n个点,将这些点成对连接起来使得所得到的n条线段不相交的方法数?

作者说的很好,看图:

这篇关于代码随想录算法训练营第36期DAY43的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL的配置文件详解及实例代码

《MySQL的配置文件详解及实例代码》MySQL的配置文件是服务器运行的重要组成部分,用于设置服务器操作的各种参数,下面:本文主要介绍MySQL配置文件的相关资料,文中通过代码介绍的非常详细,需要... 目录前言一、配置文件结构1.[mysqld]2.[client]3.[mysql]4.[mysqldum

Python多线程实现大文件快速下载的代码实现

《Python多线程实现大文件快速下载的代码实现》在互联网时代,文件下载是日常操作之一,尤其是大文件,然而,网络条件不稳定或带宽有限时,下载速度会变得很慢,本文将介绍如何使用Python实现多线程下载... 目录引言一、多线程下载原理二、python实现多线程下载代码说明:三、实战案例四、注意事项五、总结引

IDEA与MyEclipse代码量统计方式

《IDEA与MyEclipse代码量统计方式》文章介绍在项目中不安装第三方工具统计代码行数的方法,分别说明MyEclipse通过正则搜索(排除空行和注释)及IDEA使用Statistic插件或调整搜索... 目录项目场景MyEclipse代码量统计IDEA代码量统计总结项目场景在项目中,有时候我们需要统计

MySQL设置密码复杂度策略的完整步骤(附代码示例)

《MySQL设置密码复杂度策略的完整步骤(附代码示例)》MySQL密码策略还可能包括密码复杂度的检查,如是否要求密码包含大写字母、小写字母、数字和特殊字符等,:本文主要介绍MySQL设置密码复杂度... 目录前言1. 使用 validate_password 插件1.1 启用 validate_passwo

MySQL实现多源复制的示例代码

《MySQL实现多源复制的示例代码》MySQL的多源复制允许一个从服务器从多个主服务器复制数据,这在需要将多个数据源汇聚到一个数据库实例时非常有用,下面就来详细的介绍一下,感兴趣的可以了解一下... 目录一、多源复制原理二、多源复制配置步骤2.1 主服务器配置Master1配置Master2配置2.2 从服

Go语言使用net/http构建一个RESTful API的示例代码

《Go语言使用net/http构建一个RESTfulAPI的示例代码》Go的标准库net/http提供了构建Web服务所需的强大功能,虽然众多第三方框架(如Gin、Echo)已经封装了很多功能,但... 目录引言一、什么是 RESTful API?二、实战目标:用户信息管理 API三、代码实现1. 用户数据

Java对接MQTT协议的完整实现示例代码

《Java对接MQTT协议的完整实现示例代码》MQTT是一个基于客户端-服务器的消息发布/订阅传输协议,MQTT协议是轻量、简单、开放和易于实现的,这些特点使它适用范围非常广泛,:本文主要介绍Ja... 目录前言前置依赖1. MQTT配置类代码解析1.1 MQTT客户端工厂1.2 MQTT消息订阅适配器1.

C++归并排序代码实现示例代码

《C++归并排序代码实现示例代码》归并排序将待排序数组分成两个子数组,分别对这两个子数组进行排序,然后将排序好的子数组合并,得到排序后的数组,:本文主要介绍C++归并排序代码实现的相关资料,需要的... 目录1 算法核心思想2 代码实现3 算法时间复杂度1 算法核心思想归并排序是一种高效的排序方式,需要用

springboot项目中集成shiro+jwt完整实例代码

《springboot项目中集成shiro+jwt完整实例代码》本文详细介绍如何在项目中集成Shiro和JWT,实现用户登录校验、token携带及接口权限管理,涉及自定义Realm、ModularRe... 目录简介目的需要的jar集成过程1.配置shiro2.创建自定义Realm2.1 LoginReal

SpringBoot集成Shiro+JWT(Hutool)完整代码示例

《SpringBoot集成Shiro+JWT(Hutool)完整代码示例》ApacheShiro是一个强大且易用的Java安全框架,提供了认证、授权、加密和会话管理功能,在现代应用开发中,Shiro因... 目录一、背景介绍1.1 为什么使用Shiro?1.2 为什么需要双Token?二、技术栈组成三、环境