LeetCode Hot 100:动态规划
LeetCode Hot 100:动态规划
70. 爬楼梯
class Solution {
public:int climbStairs(int n) {if (n == 0)return 0;vector<int> dp(n + 1);// 初始化dp[0] = 1;// 状态转移for (int i = 1; i <= n; i++) {dp[i] += dp[i - 1];if (i >= 2)dp[i] += dp[i - 2];}return dp[n];}
};
118. 杨辉三角
class Solution {
public:vector<vector<int>> generate(int numRows) {vector<vector<int>> ans(numRows);for (int i = 0; i < numRows; i++) {ans[i].resize(i + 1);ans[i][0] = ans[i][i] = 1;}for (int i = 1; i < numRows; i++)for (int j = 1; j < i; j++)ans[i][j] = ans[i - 1][j - 1] + ans[i - 1][j];return ans;}
};
198. 打家劫舍
class Solution {
public:int rob(vector<int>& nums) {if (nums.empty())return 0;int n = nums.size();if (n == 1)return nums[0];vector<int> dp(n + 1);// 初始化dp[0] = 0;dp[1] = nums[0];// 状态转移for (int i = 2; i <= n; i++)dp[i] = max(dp[i - 1], dp[i - 2] + nums[i - 1]);return dp[n];}
};
279. 完全平方数
思路 1:动态规划
class Solution {
public:int numSquares(int n) {// dp[i]: 最少需要多少个数的平方来表示 ivector<int> dp(n + 1);// 初始化dp[0] = 0;for (int i = 1; i <= n; i++) {int minCnt = INT_MAX;for (int j = 1; j * j <= i; j++)minCnt = min(minCnt, dp[i - j * j]);dp[i] = minCnt + 1;}return dp[n];}
};
思路 2:记忆化搜索
@cache
def dfs(i: int, j: int) -> int:if i == 0:return inf if j else 0if j < i * i:return dfs(i - 1, j) # 只能不选res1 = dfs(i - 1, j) # 不选res2 = dfs(i, j - i * i) + 1 # 选return min(res1, res2)class Solution:def numSquares(self, n: int) -> int:return dfs(isqrt(n), n)
322. 零钱兑换
class Solution {
public:int coinChange(vector<int>& coins, int amount) {if (coins.empty())return -1;if (amount == 0)return 0;int n = coins.size();if (n == 1 && amount % coins[0])return -1;// dp[i]: vector<int> dp(amount + 1, INT_MAX / 2);// 初始化dp[0] = 0;// 状态转移for (int i = 1; i <= amount; i++)for (int& coin : coins) {if (i < coin)continue;dp[i] = min(dp[i], dp[i - coin] + 1);}return dp[amount] == INT_MAX / 2 ? -1 : dp[amount];}
};
139. 单词拆分
class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {int n = s.length();// dp[i]: s[0,...,i] 是否可以利用 wordDict 拼接出来vector<bool> dp(n + 1, false);// 初始化dp[0] = true;// 状态转移for (int i = 1; i <= n; i++)for (string& word : wordDict) {int len = word.length();if (i >= len && s.substr(i - len, len) == word)dp[i] = dp[i] | dp[i - len];}return dp[n];}
};
300. 最长递增子序列
思路 1:贪心 + 二分查找
class Solution {
public:int lengthOfLIS(vector<int>& nums) {vector<int> lis;for (int& num : nums) {auto it = lower_bound(lis.begin(), lis.end(), num);if (it == lis.end())lis.push_back(num); // >=num 的 lis[j] 不存在else*it = num;}return lis.size();}
};
思路 2:动态规划
class Solution {
public:int lengthOfLIS(vector<int>& nums) {if (nums.empty())return 0;int n = nums.size();if (n == 1)return 1;vector<int> dp(n, 1);// 初始化for (int i = 0; i < n; i++)dp[i] = 1;int maxLen = 0;// 状态转移for (int i = 0; i < n; i++)for (int j = 0; j < i; j++) {if (nums[j] < nums[i])dp[i] = max(dp[i], dp[j] + 1);maxLen = max(maxLen, dp[i]);}return maxLen;}
};
152. 乘积最大子数组
class Solution {
public:int maxProduct(vector<int>& nums) {int n = nums.size();vector<int> minF(n, 0), maxF(n, 0);// 初始化minF[0] = nums[0];maxF[0] = nums[0];// 状态转移for (int i = 1; i < n; i++) {minF[i] =min({nums[i], minF[i - 1] * nums[i], maxF[i - 1] * nums[i]});maxF[i] =max({nums[i], minF[i - 1] * nums[i], maxF[i - 1] * nums[i]});}return *max_element(maxF.begin(), maxF.end());}
};
416. 分割等和子集
思路 1:0-1背包
class Solution {
public:bool canPartition(vector<int>& nums) {if (nums.empty())return false;int sum = accumulate(nums.begin(), nums.end(), 0);if (sum % 2 == 1)return false;int n = nums.size();int target = sum / 2;// dp[i,j]:前i个数字、总和不超过j的情况下,能否满足j == targetvector<vector<bool>> dp(n + 1, vector<bool>(target + 1, false));// 初始化dp[0][0] = true;// 状态转移for (int i = 1; i <= n; i++)for (int j = 1; j <= target; j++) {int w = nums[i - 1];if (j >= w)dp[i][j] = dp[i - 1][j] || dp[i - 1][j - w]; // 选elsedp[i][j] = dp[i - 1][j]; // 不选}return dp[n][target];}
};
思路 1:栈
class Solution {
public:int longestValidParentheses(string s) {if (s.empty())return 0;int maxLen = 0;stack<int> stk;stk.push(-1);for (int i = 0; i < s.length(); i++) {if (s[i] == '(')stk.push(i);else {stk.pop();if (stk.empty())stk.push(i);elsemaxLen = max(maxLen, i - stk.top());}}return maxLen;}
};
思路 2:动态规划
class Solution {
public:int longestValidParentheses(string s) {if (s.empty())return 0;int n = s.length();// dp[i]: 表示以下标 i 字符结尾的最长有效括号的长度vector<int> dp(n, 0);int maxLen = 0;// 状态转移for (int i = 1; i < n; i++) {if (s[i] == ')') {if (s[i - 1] == '(')dp[i] = (i >= 2 ? dp[i - 2] : 0) + 2;else if (i - dp[i - 1] > 0 && s[i - dp[i - 1] - 1] == '(')dp[i] = dp[i - 1] + ((i - dp[i - 1] - 2) >= 0 ? dp[i - dp[i - 1] - 2] : 0) + 2;}maxLen = max(maxLen, dp[i]);}return maxLen;}
};
相关文章:
LeetCode Hot 100:动态规划
LeetCode Hot 100:动态规划 70. 爬楼梯 class Solution { public:int climbStairs(int n) {if (n 0)return 0;vector<int> dp(n 1);// 初始化dp[0] 1;// 状态转移for (int i 1; i < n; i) {dp[i] dp[i - 1];if (i > 2)dp[i] dp[i - 2];}return …...
使用Python制作雪景图片教程
如果你想用Python写一个程序来输出有关“深夜雪”的诗意文本或描述,可以通过简单的字符串输出来实现。以下是一个示例代码,展示如何用Python来描绘深夜雪的场景。 # 定义深夜雪的描述 description """ 夜幕降临,天空洒下银色…...
S-Function
目录 S-Function介绍 生成S-Function的三种常用手段 使用手写S-函数合并定制代码 使用S-Function Builder块合并定制代码 使用代码继承工具合并定制代码 S-Function介绍 我们可以使用S-Function扩展Simulink对仿真和代码生成的支持。例如,可以使用它们…...
如何具备阅读JAVA JDK虚拟机源码能力
源码位置https://github.com/openjdk/jdk 核心实现源码[部分截图] /* * Copyright (c) 1995, 2024, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistr…...
Python | Leetcode Python题解之第514题自由之路
题目: 题解: Test "godding" target "d"i 0left i lc 0 right i rc 0while Test[left] ! target:left - 1lc 1if left -1:left len(Test) - 1while Test[right] ! target:right 1rc 1if right len(Test):right 0prin…...
Docker 镜像下载问题及解决办法
Docker 镜像下载问题及解决办法 我在杂乱的、破旧的村庄寂寞地走过漫长的雨季,将我年少的眼光从晦暗的日子里打捞出来的是一棵棵开花的树,它们以一串串卓然不俗的花擦明了我的眼睛,也洗净了我的灵魂。 引言 在使用 Docker 时,用户…...
2分钟搞定 HarmonyOs Next创建模拟器
官方文档参考链接: 创建模拟器-管理模拟器-使用模拟器运行应用/服务-应用/服务运行-DevEco Studio - 华为HarmonyOS开发者https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/ide-emulator-create-V5 1. 首先打开Device Manager 2. 进入这个界面后…...
方形件排样优化与订单组批问题探析
方形件排样优化与订单组批问题是计算复杂度很高的组合优化问题,在工业工程中有很广泛的应用背景。为实现个性化定制生产模式,企业会选择订单组批的方式,继而通过排样优化实现批量切割,加工完成后再按照不同客户需求进行分拣&#…...
vue3组件通信--自定义事件
自定义事件是典型的子传父的方法。 为什么叫自定义事件呢?是因为我们用sendToy"getToy"这种格式写,很显然,在DOM中,没有叫sendToy的事件。 父组件FatherComponent.vue: <script setup> import ChildComponent fr…...
ubuntu 安装k3s
配置hostname的方法为 hostnamectl set-hostname k3sserver hostnamectlsudo apt-get update && sudo apt-get upgrade -y sudo apt-get install -y curl#手动下载v1.31.1k3s1 https://github.com/k3s-io/k3s/releases/tag/v1.31.1%2Bk3s1 #将k3s-airgap-images-amd64…...
SQL CHECK 约束:确保数据完整性的关键
SQL CHECK 约束:确保数据完整性的关键 在数据库管理中,确保数据的完整性和准确性是至关重要的。SQL(Structured Query Language)提供了多种约束条件来帮助实现这一目标,其中之一就是 CHECK 约束。本文将深入探讨 SQL CHECK 约束的概念、用法和优势,并展示如何在不同的数…...
C++ | Leetcode C++题解之第502题IPO
题目: 题解: typedef pair<int,int> pii;class Solution { public:int findMaximizedCapital(int k, int w, vector<int>& profits, vector<int>& capital) {int n profits.size();int curr 0;priority_queue<int, vect…...
《虚拟现实的边界:探索虚拟世界的未来可能》
内容概要 在虚拟现实(VR)技术的浪潮中,我们见证了其从实验室的奇想逐渐走向日常生活的非凡旅程。技术发展的背后是不断突破的创新,早期的设备虽然笨重,但如今却趋向精致、轻巧,用户体验显著提升。想象一下…...
Rust教程
2024 Rust现代实用教程:1.1Rust简介与安装更新––2024 Rust现代实用教程:1.2编译器与包管理工具以及开发环境–––––––––––...
测试代理IP的有效性和可用性
使用代理IP的有效性和可用性直接关系到用户的工作效率,尤其是在进行数据抓取、网络爬虫和保护个人隐私等场景中。 一、测试代理IP的必要性 代理IP的可用性测试是确保代理服务正常运行的重要步骤。测试代理IP的必要性主要体现在以下几个方面: 提升工作…...
散列表:为什么经常把散列表和链表放在一起使用?
散列表:为什么经常把散列表和链表放在一起使用? 在计算机科学中,散列表(哈希表)和链表是两种常见的数据结构。你可能会好奇,为什么它们经常被放在一起使用呢?让我们一起来深入探讨这个问题。 一、散列表的特点 散列表是一种根据关键码值(Key value)而直接进行访问的…...
计算机网络:网络层 —— IPv4 地址与 MAC 地址 | ARP 协议
文章目录 IPv4地址与MAC地址的封装位置IPv4地址与MAC地址的关系地址解析协议ARP工作原理ARP高速缓存表 IPv4地址与MAC地址的封装位置 在数据传输过程中,每一层都会添加自己的头部信息,最终形成完整的数据包。具体来说: 应用层生成的应用程序…...
PMP--一、二、三模、冲刺、必刷--分类--10.沟通管理--技巧--文化意识
文章目录 技巧一模10.沟通管理--1.规划沟通管理--文化意识--军事背景和非军事背景人员有文化差异文化意识:题干关键词 “两拨人的背景不同、文化差异、风格差异”。5、 [单选] 项目团队由前军事和非军事小组成员组成。没有军事背景的团队成员认为前军事团队成员在他…...
FileReader和FileWriter
FileReader 使用read()方法读取单个字符,下面是如何修改使程序性能更好的过程。 第一种:处理异常方式为throws Testpublic void test() throws IOException {//读取hello.txt,并显示内容// 创建文件对象File file new File("hello.txt…...
【UE5】将2D切片图渲染为体积纹理,最终实现使用RT实时绘制体积纹理【第六篇-阶段总结篇】
因为马上就要进入下一个阶段,制作动态编辑体积纹理的模块。 但在这之前,要在这一章做最后一些整理。 首先,我们完成没完成的部分。其次,最后整理一下图表。最后,本文附上正在用的贴图 完善Shader 还记得我们之前注…...
地球村上一些可能有助于赚钱的20个思维方式
地球村上一些可能有助于赚钱的20个思维方式: 1. 目标导向思维:明确自己的财务目标,并制定详细、可执行的计划来逐步实现。 2. 创新思维:不断寻求新的商业机会和独特的解决方案,以在竞争激烈的市场中脱颖而出。 3. 价值…...
0基础入门matlab
目录 一、命令 二、变量命名 三、数据类型 数字 字符和字符串 矩阵 rand、randi和randn的区别? 元胞数组和结构体 MAGIC 结构体 四、矩阵构造、四则运算、矩阵下标 五、MATLAB逻辑与流程控制 六、MATLAB绘图 二维平面绘图 三维平面绘图 导出图片 内…...
【前端】实操tips集合
1. 关闭vue中组件名字的多词校验 (1) package.json文件中修改eslint配置 "eslintConfig": {"rules": {"vue/multi-word-component-names":"off" }}, (2).eslintrc.js或者.eslintrc配置文件中进行配置 modu…...
基于Springboot+Vue 传统文化管理系统(源码+LW+部署讲解+数据库+ppt)
!!!!!!!!! 会持续一直更新下去 有问必答 一键收藏关注不迷路 源码获取:https://pan.baidu.com/s/1aRpOv3f2sdtVYOogQjb8jg?pwdjf1d 提取码: jf1d &#…...
质量漫谈一
我知道很多同学看到这类问题,第一反应想要去寻找的就是作为测试角色,应该要如何如何去做?但是今天这里作为质量第一篇,不打算按照这样单角度去写,这类同学可以就此打住,如果在意的话,可关注后续…...
个体化神经调控 Neurolnavigation介绍
神经调控技术包括DBS, TMS, rTMS, tDCS等等。今天主要说一下TMS。 TMS全程经颅磁刺激,通过对头皮放置磁场线圈,可以定向的往局部头皮发送脉冲信号,抑制局部神经元活动。 TMS的优点是精准刺激,tDCS的优点是刺激范围比较宽泛。近期有…...
02-RT1060 双ADC采样+eDMA传输
RT1060-双ADC+eDMA外设的配合使用 该项目是基于MIMXRT1060-EVKB官方开发板编写的驱动。 一、头文件包含介绍 #include "pin_mux.h" #include "clock_config.h" #include "board.h" #include "fsl_adc.h" #include "fsl_adc_et…...
单值集合总复习
1:Object类的核心方法复习 Object 是所有类【引用数据类型】的 直接 / 间接 父类 toString(): 将一个 引用数据类型的对象 转换成 String 类型 class Object{//Sun //toString()不需要参数:将一个对象转换成字符串 将调用者转换成字符串 public String …...
Pyside6 布局管理器(4)--- QGridLayout的使用
一、QGridLayout的介绍(官翻) QGridLayout 获得可用的空间(由其父布局或 parentWidget() 提供),将其划分为行和列,并将其管理的每个小部件放入正确的单元格中。 列和行的行为是相同的;我们将…...
从GPT定制到Turbo升级再到Assistants API,未来AI世界,你准备好了吗?
引言 在OpenAI DevDay发布会上,OpenAI再次震撼整个人工智能行业,为AI领域带来了重大的更新。CEO Sam Altman宣布推出了定制版本的ChatGPT,这意味着用户现在可以根据自己的需求打造个性化的GPT,并分享至GPT Store。这一消息对于受…...
wordpress网站手机端菜单栏/公司如何在百度宣传
Apache不能启动解决办法 作者的话:遇到这个问题的时候,从网上找了很多资料,结果都是让我这个新手摸不着头绪 还好,在我长时间的查找下,还是找到了一篇文章,解决了我的烦恼,下面是我对这个文章的…...
wap网站建设公司/抖音账号权重查询
我想在SWT中的一个部分添加一个工具栏.我在PDE清单编辑器中看到了一个例子.如何添加此工具栏或按钮?也许我需要使用不同的控件?谢谢,我做解决方法:您可以使用ImageHyperLink控件.我认为这就是PDE清单编辑器使用的内容.Section section new Section(pare…...
珠海网站建设有限公司/北京优化推广
创建SpringBoot项目在线创建方式网址:https://start.spring.io/然后创建Controller、Mapper、Service包SpringBoot整合Redis引入Redis依赖<!--SpringBoot与Redis整合依赖--> <dependency><groupId>org.springframework.boot</groupId><a…...
网站建设方案封面/湘潭网页设计
Asciidoc中的“”号可以在文中任意位置存在,而成对的""号会对其中间的文字起到着色的效果,比如以下的正文: - 熟悉C语言,熟悉STL并了解对象模型,熟悉c0x常用特性,了解Qt基础 转化之后会出现这样的显示效果&a…...
wordpress 多店铺/北京seo网站开发
步骤: 1,客户端向yarn的RM提交作业请求,RM进行权限等验证,生成jobid、资源上传路径,将jobId和资源上传路径返回给客户端; 2,客户端将jar包、配置文件、第三方包等文件上传到指定的hdfs路径后&…...
西安网站建设咪豆互联/互联网营销课程体系
此函数允许创建方向强度直方图,也称为“风玫瑰”。这个工具可以用来表示这种图形。 This function allows to create a Direction-intensity histogram, also known as “Wind Roses”. This tool can be used for representing this kind of graphics. 它还能够将…...