【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 的 适用于计算机类毕业设计,课程设计参考与学习用途。仅供学习参考, 不得用于商业或者非法用途,否则,一切后果请用户自负。 看运行截图看 第五章 第四章 获取资料方式 **项…...

大白话介绍循环神经网络
循环神经网络实质为递归式的网络,它在处理时序任务表现出优良的效果,毕竟递归本来就是一步套一步的向下进行,而自然语言处理任务中涉及的文本天然满足这种时序性,比如我们写字就是从左到右一步步来的鸭,刚接触深度学习…...
椭圆曲线密码学(ECC)
一、ECC算法概述 椭圆曲线密码学(Elliptic Curve Cryptography)是基于椭圆曲线数学理论的公钥密码系统,由Neal Koblitz和Victor Miller在1985年独立提出。相比RSA,ECC在相同安全强度下密钥更短(256位ECC ≈ 3072位RSA…...
QMC5883L的驱动
简介 本篇文章的代码已经上传到了github上面,开源代码 作为一个电子罗盘模块,我们可以通过I2C从中获取偏航角yaw,相对于六轴陀螺仪的yaw,qmc5883l几乎不会零飘并且成本较低。 参考资料 QMC5883L磁场传感器驱动 QMC5883L磁力计…...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)
目录 1.TCP的连接管理机制(1)三次握手①握手过程②对握手过程的理解 (2)四次挥手(3)握手和挥手的触发(4)状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...
vue3 定时器-定义全局方法 vue+ts
1.创建ts文件 路径:src/utils/timer.ts 完整代码: import { onUnmounted } from vuetype TimerCallback (...args: any[]) > voidexport function useGlobalTimer() {const timers: Map<number, NodeJS.Timeout> new Map()// 创建定时器con…...
Rust 异步编程
Rust 异步编程 引言 Rust 是一种系统编程语言,以其高性能、安全性以及零成本抽象而著称。在多核处理器成为主流的今天,异步编程成为了一种提高应用性能、优化资源利用的有效手段。本文将深入探讨 Rust 异步编程的核心概念、常用库以及最佳实践。 异步编程基础 什么是异步…...

Linux --进程控制
本文从以下五个方面来初步认识进程控制: 目录 进程创建 进程终止 进程等待 进程替换 模拟实现一个微型shell 进程创建 在Linux系统中我们可以在一个进程使用系统调用fork()来创建子进程,创建出来的进程就是子进程,原来的进程为父进程。…...
4. TypeScript 类型推断与类型组合
一、类型推断 (一) 什么是类型推断 TypeScript 的类型推断会根据变量、函数返回值、对象和数组的赋值和使用方式,自动确定它们的类型。 这一特性减少了显式类型注解的需要,在保持类型安全的同时简化了代码。通过分析上下文和初始值,TypeSc…...
Python 高级应用10:在python 大型项目中 FastAPI 和 Django 的相互配合
无论是python,或者java 的大型项目中,都会涉及到 自身平台微服务之间的相互调用,以及和第三发平台的 接口对接,那在python 中是怎么实现的呢? 在 Python Web 开发中,FastAPI 和 Django 是两个重要但定位不…...

leetcode73-矩阵置零
leetcode 73 思路 记录 0 元素的位置:遍历整个矩阵,找出所有值为 0 的元素,并将它们的坐标记录在数组zeroPosition中置零操作:遍历记录的所有 0 元素位置,将每个位置对应的行和列的所有元素置为 0 具体步骤 初始化…...

【PX4飞控】mavros gps相关话题分析,经纬度海拔获取方法,卫星数锁定状态获取方法
使用 ROS1-Noetic 和 mavros v1.20.1, 携带经纬度海拔的话题主要有三个: /mavros/global_position/raw/fix/mavros/gpsstatus/gps1/raw/mavros/global_position/global 查看 mavros 源码,来分析他们的发布过程。发现前两个话题都对应了同一…...