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

news2025/1/11 14:52:12

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条线段不相交的方法数?

作者说的很好,看图:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1713808.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

在outlook的邮件中插入HTML;HTML模板获取

本文介绍如何在outlook发送邮件时&#xff0c;在邮件中插入HTML&#xff0c;此HTML可以从获取模板自行进行修改。 文章目录 一、下载HTML模板&#xff08;或自己制作好HTML文件&#xff09;二、outlook新增宏三、新建邮件&#xff0c;插入HTML 一、下载HTML模板&#xff08;或自…

某烟草企业数字化转型物流信息化咨询项目规划方案(117页PPT)

方案介绍&#xff1a; 烟草企业数字化转型物流信息化咨询项目规划方案将为企业带来多方面的价值&#xff0c;包括提升物流运营效率、降低物流成本、优化供应链管理、增强企业竞争力和促进可持续发展等。这些价值的实现将有助于企业在激烈的市场竞争中保持领先地位并实现可持续…

5292A 物联网信号分析仪

5292A 物联网信号分析仪 —— 10MHz&#xff5e;6GHz —— 简述 5292A物联网信号分析仪是一款通用的矢量信号分析仪&#xff0c;频率范围覆盖 10MHz&#xff5e;6GHz&#xff0c;具有良好的频率、功率测量精度和稳定度&#xff1b;支持模拟与数字调制信号、全制式的通信标准…

【408真题】2009-23

“接”是针对题目进行必要的分析&#xff0c;比较简略&#xff1b; “化”是对题目中所涉及到的知识点进行详细解释&#xff1b; “发”是对此题型的解题套路总结&#xff0c;并结合历年真题或者典型例题进行运用。 涉及到的知识全部来源于王道各科教材&#xff08;2025版&…

OpenCV:入门(四)

形态学操作 形态学&#xff0c;即数学形态学&#xff08;Mathematical Morphology&#xff09;&#xff0c;是图像处理过程中一个非常重要的研 究方向。形态学主要从图像内提取分量信息&#xff0c;该分量信息通常对于表达和描绘图像的形状具有 重要意义&#xff0c;通常是图像…

花钱学谢宁DOE培训,投入产出比到底如何?

在当今这个快速发展的时代&#xff0c;无论是职场人士还是创业者&#xff0c;都渴望通过不断学习来提升自我能力&#xff0c;以便在竞争激烈的市场中脱颖而出。其中&#xff0c;谢宁DOE培训因其独特的理念和方法&#xff0c;吸引了众多求学者的目光。然而&#xff0c;面对不菲的…

从零开始利用MATLAB进行FPGA设计(六)用ADC采集信号教程1

黑金的教程做的实在太拉闸了&#xff0c;于是自己摸索信号采集模块的使用方法。 ADC模块&#xff1a;AN9238 FPGA开发板&#xff1a;AX7020&#xff1b;Xilinx 公司的 Zynq7000 系列的芯片XC7Z020-2CLG400I&#xff0c;400引脚 FBGA 封装。 往期回顾&#xff1a; 从零开始利…

Vue项目运行页面禁止缩放【移动端和PC端都禁止缩放】解决方案

Vue项目运行页面禁止缩放【移动端和PC端都禁止缩放】解决方案&#xff0c;有的人手很J,总喜欢放大缩小&#xff0c;从而会导致页面错乱&#xff0c;以下是解决方案&#xff0c;简单有效 效果图PC&#xff1a;滚轮缩放和其他缩放都会禁止 移动端效果图&#xff1a;各种手机平板…

Python数据处理,使用 tkinter 模块点击获取文件目录

Python数据处理&#xff0c;使用 tkinter 模块点击获取文件目录 正文 正文 当我们进行数据处理读取文件内数据的时候&#xff0c;通常&#xff0c;我们需要设定好一个存放当前文件所在目录的变量。比如如下目录&#xff1a; file_path rC:\Users\xxx\Desktop\DataSet\Data.c…

20240528解决飞凌的OK3588-C的核心板的TYPE-C1接口识别问题

20240528解决飞凌的OK3588-C的核心板的TYPE-C1接口识别问题 2024/5/28 16:46 缘起&#xff1a; 现阶段碰到的USB相关的问题&#xff1a;&#xff08;LINUX R4版本&#xff09; 1、USB3.0插USB摄像头 lsusb找不到设备 2、刷机口只接了3根线&#xff0c;GND/D/D-&#xff0c;可以…

vue3 + ts 实现IP地址及Mac地址输入框功能

1、组件完成代码 <template><div class"ip-input"><div v-for"(item, index) in ipArr" :key"index" class"ip-input__item-wrap"><input ref"ipInput" v-model"ipArr[index]" type"t…

Python装饰器的应用

Python 中的装饰器是一种语法糖&#xff0c;可以在运行时&#xff0c;动态的给函数或类添加功能。装饰器本质上是一个函数&#xff0c;使用 函数名就是可实现绑定给函数的第二个功能 。它的作用就是在不修改被装饰对象源代码和调用方式的前提下为被装饰对象添加额外的功能。 …

清华大学提出IFT对齐算法,打破SFT与RLHF局限性

监督微调&#xff08;Supervised Fine-Tuning, SFT&#xff09;和基于人类反馈的强化学习&#xff08;Reinforcement Learning from Human Feedback, RLHF&#xff09;是预训练后提升语言模型能力的两大基础流程&#xff0c;其目标是使模型更贴近人类的偏好和需求。 考虑到监督…

奥利奥罚单背后的启示:企业合规与反垄断的边界

在全球化的经济环境中&#xff0c;企业面临着激烈的市场竞争。为了在竞争中脱颖而出&#xff0c;一些企业可能会采取不正当的竞争手段&#xff0c;如垄断、价格歧视等。然而&#xff0c;这些行为往往会触犯反垄断法规&#xff0c;给企业带来严重的法律风险。最近&#xff0c;奥…

jsp音乐网站的设计与实现

需求收集 经过与客户探讨后 得到初步的活动图,此活动图叙述了游客、会员、管理员在网站的活动得到初步的类图得到网站功能包图得到用例图 ●活动图 ●初步的类图 注&#xff1a;为得到良好的安全性&#xff0c;登入管理员的时候&#xff0c;应该再输入管理员密码.所以在admin…

AI联想扩图解决方案,智能联想,无需人工干预

对于众多企业而言&#xff0c;无论是广告宣传、产品展示还是客户体验&#xff0c;高质量、宽广视野的图像都是不可或缺的。受限于车载摄像头等设备的物理限制&#xff0c;我们往往难以捕捉到完整、宽广的视觉场景。针对这一挑战&#xff0c;美摄科技凭借其前沿的AI联想扩图解决…

Vue3实战笔记(50)—Vue 3+ECharts还能看股票?附源码

文章目录 前言一、改进之前的封装echarts组件二、封装股票k线图总结 前言 今天封装股票k线图组件 前几天学的几个知识点都有用到&#xff0c;都是在封装k线图的时候遇到的问题&#xff0c;又啃了一遍基础。 一、改进之前的封装echarts组件 使用ref对象方式封装useEChartsRef.t…

git 学习随笔

git 学习随笔 基本概念 git 对待数据类似快照流的形式而不是类似 cvs 那样的纪录文件随时间逐步积累的差异 git 中所有数据在存储钱都会计算校验和&#xff08;hash) 三种状态&#xff1a;已提交(committed)&#xff0c;已修改(modified)&#xff0c;已暂存(staged)。 add…

计算机图形学入门03:二维变换

变换(Transformation)可分为模型(Model)变换和视图(Viewing)变换。在3D虚拟场景中相机的移动和旋转&#xff0c;角色人物动画都需要变换&#xff0c;用来描述物体运动。将三维世界投影变换到2D屏幕上成像出来&#xff0c;也需要变换。 1.缩放变换 缩放(Scale)变换&#xff1a; …

电脑提示:“找不到vcruntime140_1.dll无法执行”该怎么恢复?一键修复vcruntime140_1.dll丢失

vcruntime140_1.dll是一个关键的系统文件&#xff0c;它在电脑运行过程中被调用。如果该文件丢失或找不到&#xff0c;将会导致弹出"找不到vcruntime140_1.dll无法执行"的错误提示。缺失vcruntime140_1.dll文件将导致软件或游戏无法正常打开或运行。 一键修复vcrunti…