【leetcode100-086到090】【动态规划】一维五题合集2
【单词拆分】
给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。
注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。
思路:
首先,我们依次考虑s的前i个字母能否被分割,直到i=n;
对一个确定的i,我们尝试在前i个字母中进行分割,枚举每一个分割点,如果分割点前面的部分能分割(肯定已经被计算过,直接查表即可),且分割点后的部分存在于 wordDict中,那么当前子串就是可分割的,记录到表中;
最后检查dp[n]即可。
class Solution {
public:bool wordBreak(string s, vector<string>& wordDict) {int n = s.size();// dpvector<bool> dp(n + 1, false);dp[0] = true;//递推for (int i = 1; i <= n; i++) {for (int j = 0; j < i; j++) {//bool flag=false;// s[0]到s[j-1]能分割,s[j]到s[i-1]if (dp[j] &&(find(wordDict.begin(),wordDict.end(),s.substr(j, i - j)) != wordDict.end())) {dp[i] = true;break;}}}return dp[n];}
};
【最长递增子序列】
给你一个整数数组 nums ,找到其中最长严格递增子序列的长度。
子序列 是由数组派生而来的序列,删除(或不删除)数组中的元素而不改变其余元素的顺序。例如,[3,6,2,7] 是数组 [0,3,1,6,2,2,7] 的子序列。
思路:
依次考虑前i个元素,计算以第i个元素结尾的递增子序列长度;
对第i个元素,我们检查它前面的所有元素,并试着把它接在该元素结尾的子序列后面,如果还能满足递增,则记录接上后的子序列长度;
随时记录当前找到的最大长度。
class Solution {
public:int lengthOfLIS(vector<int>& nums) {int n = nums.size();vector<int> dp(n, 1);for (int i = 0; i < n; i++) {int curMax = 1;for (int j = 0; j < i; j++) {if (nums[j] < nums[i])curMax = max(curMax, dp[j] + 1);}dp[i]=curMax;}return *max_element(dp.begin(),dp.end());}
};
【乘积最大子数组】
给你一个整数数组 nums ,请你找出数组中乘积最大的非空连续子数组(该子数组中至少包含一个数字),并返回该子数组所对应的乘积。
测试用例的答案是一个 32-位 整数。
子数组 是数组的连续子序列。
思路:
本题重点在于,会出现负数,想让一个包含负数的数组乘积最大,要么让这个负数乘绝对值最大的负数前缀乘积(实际值最小),要么什么也不干(如果前缀只有正数,乘正数要么不变要么变小,直接不考虑);
再考虑正数情况,想让一个包含该数的数组乘积最大,要么让它乘上最大的正的前缀乘积,要么什么也不干(前缀积只有负数时越乘越小);
如果遇到0,包含它的子数组乘积必为零,我们可以留到最后去判断;
以上逻辑看起来很复杂,要判断当前元素和0的关系,最大的前缀积最小的前缀积和零的关系,特殊值0的处理,等等,但实际上不管怎么样,我们需要的其实就是到当前元素为止的最大和最小乘积,而我们做的计算也只有当前元素x最大前缀积,当前元素x最小前缀积,当前元素不变三种情况,所以只要计算这三种结果,并取其中的最大值和最小值就可。
class Solution {
public:int maxProduct(vector<int>& nums) {int ans = INT_MIN;int n = nums.size();int dpMax = 1;int dpMin = 1;for (int i = 0; i < n; i++) {int temp=dpMax;dpMax =max(max(nums[i], nums[i] * dpMax), nums[i] * dpMin);dpMin =min(min(nums[i], nums[i] * temp), nums[i] * dpMin);ans = max(ans, dpMax);}return ans;}
};
【分割等和自己】
给你一个 只包含正整数 的 非空 数组 nums 。请你判断是否可以将这个数组分割成两个子集,使得两个子集的元素和相等。
思路:
把题目翻译一下,其实就是能不能找出一个子数组,它的和是原数组总和的一半,这样就变成0-1背包了;
首先算一下原数组总和,如果是奇数肯定不行,如果是偶数,那么它的一半就是我们要找的子数组的和,aka背包的容量,而我们要记录的是考虑前i个物品时能否恰好把容量为j的背包装满;
依次增加当前考虑的物品数量i,倒序遍历背包容量j,首先判断当前物品i,如果它的重量正好等于当前容量j,那么可以装满,如果前i-1个物品已经能把j容量装满,那么增加一个物品没有影响,肯定也可以装满,否则考虑前i-1个物品能否装满容量j-当前重量的背包,如果能的话,加上当前物品,就正好是前i个物品装满j容量的背包;
最后,考虑到每一轮循环我们需要的信息其实都只有第i-1行,进行空间优化,用一维数组来滚动即可。
class Solution {
public:bool canPartition(vector<int>& nums) {int n = nums.size();sort(nums.begin(), nums.end());int sum=0;for(int i=0; i<n; i++){sum += nums[i];}if(sum%2 || sum<nums[n-1]) return false;int target = sum/2;vector<bool> dp(target+1);dp[0]=true;for(int i=0; i<n; i++){for(int j=target; j>=nums[i]; j--){dp[j] = dp[j] || dp[j-nums[i]];}}return dp[target];}
};
【最长有效括号】
给你一个只包含 '(' 和 ')' 的字符串,找出最长有效(格式正确且连续)括号子串的长度。
思路:
一开始疯狂条件判断,把自己都判晕了,后来才意识到本题的核心逻辑非常简单,归纳真有意思。
遍历串中的每个字符,我们记录以该字符结尾的最长有效子串长度;
当我们拿到一个新的字符i,有两种情况,左括号结尾的必无效,填0直接continue,右括号结尾时,我们要做的是:看看这个右括号能不能找到对应的左括号,把以字符i-1结尾的有效串包在里面,如果找到了,那么这个有效串的长度就增加了2,还没完,我们找到了最左边的括号以后,还要看看它的前一个字符能提供多长的有效串,拼接起来,此时才真正拿到了以字符i结尾的最长的有效串;
对当前字符是右括号且前一个字母是左括号的情况,我们还可以进行代码优化,直接用这两个字符组成的合法括号对拼接上前面的有效串即可(本质是用dp[i - 1]为0的信息简化了表达式)。
class Solution {
public:int longestValidParentheses(string s) {int n = s.size();if (n == 0)return 0;vector<int> dp(n + 1, 0);//dp[0] = dp[1] = 0;for (int i = 2; i <= n; i++) {//左结尾必不合法if (s[i - 1] == '(')continue;//右结尾时分情况讨论else {//正好是个左,凑一对if (s[i - 2] == '(')dp[i] = dp[i - 2] + 2;//是个右,要去当前元素左边的整个合法串的左边找找有没有配对的,配上的话还要再往前接龙else {//配上了if ((i - 2 - dp[i - 1] >= 0) &&(s[i - 2 - dp[i - 1]] == '('))dp[i] = dp[i - 1] + 2 + dp[i - 2 - dp[i - 1]];}}}return *max_element(dp.begin(), dp.end());}
};
相关文章:
【leetcode100-086到090】【动态规划】一维五题合集2
【单词拆分】 给你一个字符串 s 和一个字符串列表 wordDict 作为字典。如果可以利用字典中出现的一个或多个单词拼接出 s 则返回 true。 注意:不要求字典中出现的单词全部都使用,并且字典中的单词可以重复使用。 思路: 首先,我…...
关闭Ubuntu 默认开启的自动安全更新
简介 Ubuntu 和 Debian 应该从很早版本开始预装unattended-upgrades 包,并开启自动更新有安全问题的软件包。 (最小化安装不会安装此包) 有什么影响? 如果软件包有安全漏洞,Ubuntu发布更新包后会自动安装更新并重启…...
python统计文本 2022年9月青少年电子学会等级考试 中小学生python编程等级考试二级真题答案解析
目录 python统计文本 一、题目要求 1、编程实现 2、输入输出...
HomeAssistant系统添加HACS插件商店与远程控制家中智能家居
文章目录 基本条件一、下载HACS源码二、添加HACS集成三、绑定米家设备 上文介绍了如何实现群晖Docker部署HomeAssistant,通过内网穿透在户外控制家庭中枢。本文将介绍如何安装HACS插件商店,将米家,果家设备接入 Home Assistant。 基本条件…...
计算huggingface模型占用硬盘空间的实战代码
大家好,我是herosunly。985院校硕士毕业,现担任算法研究员一职,热衷于机器学习算法研究与应用。曾获得阿里云天池比赛第一名,CCF比赛第二名,科大讯飞比赛第三名。拥有多项发明专利。对机器学习和深度学习拥有自己独到的见解。曾经辅导过若干个非计算机专业的学生进入到算法…...
Leetcode 3031. Minimum Time to Revert Word to Initial State II
Leetcode 3031. Minimum Time to Revert Word to Initial State II 1. 解题思路2. 代码实现 题目链接:3031. Minimum Time to Revert Word to Initial State II 1. 解题思路 这一题就是一个z算法的题目,算是比较套路的题目了。 关于z算法,…...
游戏后端如何实现服务器之间的负载均衡?
在当今的游戏行业中,随着游戏用户数量的不断增加,如何实现服务器之间的负载均衡成为了一个亟待解决的问题。游戏后端作为游戏的重要组成部分,承载着游戏逻辑处理和数据存储等功能,因此游戏后端的负载均衡问题尤为重要。本文将详细…...
es6中标签模板
之所以写这篇文章,是因为标签模板是一个很容易让人忽略的知识点 首先我们已经非常熟悉模板字符串的使用方法 const name "诸葛亮" const templateString hello, My name is ${name}标签模板介绍 这里的标签模板其实不是模板,而是函数调用…...
二级C语言笔试1
(总分96,考试时间90分钟) 一、选择题 下列各题A)、B)、C)、D)4个选项中,只有1个选项是正确的。 1. 有以下程序: void sum(int a[]) a[0]a[-1]a[1]; main() int a[10]1,2,3,4,5,6,7,8,9,10; sum(&a[2]); printf(…...
Spring MVC跨域设置
简介 出于安全方面考虑,浏览器发起请求时,会先检查同源策略(协议、主机、端口是否与当前页面相同),不匹配则认为是跨域请求。 CORS (Cross-Origin Resource Sharing) CORS是一种机制,允许服务器声明哪些…...
基于Python的HTTP隧道安全性分析:魔法背后的锁与钥匙
当我们谈论基于Python的HTTP隧道时,不禁让人想起那些神秘的魔法门。但是,在魔法背后,我们也需要确保安全性,就像需要确保魔法不会落入邪恶之手一样。那么,基于Python的HTTP隧道在安全性方面表现如何呢?让我…...
linux的stat/lstat函数和目录遍历函数使用
stat函数: 作用:获取文件属性 函数原型:int stat(const char *pathname, struct stat *statbuf); 返回值:成功返回0 失败返回-1 struct stat { dev_t st_dev; //文件设备编号 ino_…...
HTTP MIME 类型
MIME - Multipurpose Internet Mail Extension, 多用途因特网邮件扩展,起初是为了解决不同的电子邮件系统之间搬移报文时存在的问题。MIME 在电子邮件系统中工作得非常好,因此 HTTP 也采纳了它,用它来描述并标记多媒体内容。 MIME 类…...
Mac OS中创建适合网络备份的加密镜像文件:详细步骤与参数选择
这篇文章提供了在Mac OS中创建适合网络备份的加密镜像文件的详细步骤,同时探讨了在选择相关参数时的关键考虑因素,以确保用户能够安全、高效地存储和保护重要数据。 创建步骤 在Mac OS Monterey中,你可以使用“磁盘工具”(Disk …...
Java TreeSet 添加自定义对象 必须指定排序规则
Java TreeSet 添加自定义对象 必须指定排序规则 package com.zhong.collection.set;import java.util.Comparator; import java.util.TreeSet;public class TreeSetDemo {public static void main(String[] args) {// TreeSet 添加自定义数据类型 应该自定义排序规则TreeSet<…...
vue - 指令(一)
看文章可以得到什么? 1.可以快速的了解并会使用vue的指令 2.可以加深你对vue指令的理解,知道每个指令代表什么功能 目录 什么是vue的指令? vue常见指令的使用 v-html v-show v-if v-else 和v-else-…...
正则表达式 regex
文章目录 参考 参考 https://blog.csdn.net/Conradine_Lian/article/details/108890595 regex可以很简单 也可以很复杂 /* 限定符 修饰前面的一个字符,可以是元字符* 重复0次或更多次 重…...
iOS自动打包如何用Python实现
在Python中实现iOS自动打包的过程需要使用第三方库和工具,如pyobjc和appdirs。以下是一个基本的Python脚本示例,用于自动打包iOS应用程序: python复制代码 import os import appdirs import subprocess import pyobjc # 获取应用程序目…...
springboot161基于springboot的公交线路查询系统
简介 【毕设源码推荐 javaweb 项目】基于springbootvue 的 适用于计算机类毕业设计,课程设计参考与学习用途。仅供学习参考, 不得用于商业或者非法用途,否则,一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…...
大白话介绍循环神经网络
循环神经网络实质为递归式的网络,它在处理时序任务表现出优良的效果,毕竟递归本来就是一步套一步的向下进行,而自然语言处理任务中涉及的文本天然满足这种时序性,比如我们写字就是从左到右一步步来的鸭,刚接触深度学习…...
Docker 离线安装指南
参考文章 1、确认操作系统类型及内核版本 Docker依赖于Linux内核的一些特性,不同版本的Docker对内核版本有不同要求。例如,Docker 17.06及之后的版本通常需要Linux内核3.10及以上版本,Docker17.09及更高版本对应Linux内核4.9.x及更高版本。…...
Java - Mysql数据类型对应
Mysql数据类型java数据类型备注整型INT/INTEGERint / java.lang.Integer–BIGINTlong/java.lang.Long–––浮点型FLOATfloat/java.lang.FloatDOUBLEdouble/java.lang.Double–DECIMAL/NUMERICjava.math.BigDecimal字符串型CHARjava.lang.String固定长度字符串VARCHARjava.lang…...
五年级数学知识边界总结思考-下册
目录 一、背景二、过程1.观察物体小学五年级下册“观察物体”知识点详解:由来、作用与意义**一、知识点核心内容****二、知识点的由来:从生活实践到数学抽象****三、知识的作用:解决实际问题的工具****四、学习的意义:培养核心素养…...
镜像里切换为普通用户
如果你登录远程虚拟机默认就是 root 用户,但你不希望用 root 权限运行 ns-3(这是对的,ns3 工具会拒绝 root),你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案:创建非 roo…...
CMake 从 GitHub 下载第三方库并使用
有时我们希望直接使用 GitHub 上的开源库,而不想手动下载、编译和安装。 可以利用 CMake 提供的 FetchContent 模块来实现自动下载、构建和链接第三方库。 FetchContent 命令官方文档✅ 示例代码 我们将以 fmt 这个流行的格式化库为例,演示如何: 使用 FetchContent 从 GitH…...
短视频矩阵系统文案创作功能开发实践,定制化开发
在短视频行业迅猛发展的当下,企业和个人创作者为了扩大影响力、提升传播效果,纷纷采用短视频矩阵运营策略,同时管理多个平台、多个账号的内容发布。然而,频繁的文案创作需求让运营者疲于应对,如何高效产出高质量文案成…...
JS设计模式(4):观察者模式
JS设计模式(4):观察者模式 一、引入 在开发中,我们经常会遇到这样的场景:一个对象的状态变化需要自动通知其他对象,比如: 电商平台中,商品库存变化时需要通知所有订阅该商品的用户;新闻网站中࿰…...
使用Spring AI和MCP协议构建图片搜索服务
目录 使用Spring AI和MCP协议构建图片搜索服务 引言 技术栈概览 项目架构设计 架构图 服务端开发 1. 创建Spring Boot项目 2. 实现图片搜索工具 3. 配置传输模式 Stdio模式(本地调用) SSE模式(远程调用) 4. 注册工具提…...
A2A JS SDK 完整教程:快速入门指南
目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库ÿ…...
C#中的CLR属性、依赖属性与附加属性
CLR属性的主要特征 封装性: 隐藏字段的实现细节 提供对字段的受控访问 访问控制: 可单独设置get/set访问器的可见性 可创建只读或只写属性 计算属性: 可以在getter中执行计算逻辑 不需要直接对应一个字段 验证逻辑: 可以…...
