算法(26)-最长系列

最长系列

  • 1.LeetCode-32 最长有效括号--子串
  • 2.LeetCode-300 最长上升子序列--长度
  • 3.LeetCode-32 最长回文子串--是什么
  • 5.LeetCode-512 最长回文子序列--长度
  • 6.LeetCode-1143 最长公共子序列--长度
  • 6.LeetCode-128 最长连续序列--长度
  • 7.LeetCode-14 最长公共前缀-字符串
  • 8.剑指offer-48 最长不含重复字符串的子字符串-长度

列表-子序列(连续/不连续)
字符串-子序列(不连续),子串(连续)


1.一维dp,dp[i] --以item[i]结尾的,有效的,最长XXX的长度


1.LeetCode-32 最长有效括号–子串

题目:给定一个只包含 ‘(’ 和 ‘)’ 的字符串s,找出最长的包含有效括号的子串的长度。

dp[i] --以s[i]结尾的,有效的子串的长度中,最长的一个。

显然有效的子串一定以)结尾,因此我们可以知道以(结尾的子串对应的dp 值必定为 0,我们只需要求解 )在dp 数组中对应位置的值。

同时因为子串要求连续,所以可以用相邻的dp[i-2]来更新符合条件的dp[i](s[i]==")"ands[i−1]=="("=>dp[i]=dp[i−2]+2s[i]==")" and \ s[i-1]=="("=>dp[i] = dp[i-2]+2s[i]==")"and s[i1]=="("=>dp[i]=dp[i2]+2})

# 1.s[i]==")" and s[i-1]=="("    dp[i] = dp[i-2]+2
# 2.s[i]==")" and s[i-1]==")"    dp[i] = dp[i-1] + dp[i-dp[i-1]-2]+2 下标的合理性
# ((xx)) dp[i-1] 也有效的情况下
def longestValidParentheses(self, s):n=len(s)if n<2:return 0dp=[0]*nres=0for i in range(1,n):if i==1:if s[i]==")" and s[i-1]=="(":dp[1]=2else:if s[i]==")" and s[i-1]=="(":dp[i]=dp[i-2]+2               if s[i]==")" and s[i-1]==")":if i-1-dp[i-1]>=0 and s[i-1-dp[i-1]]=="(":dp[i]=dp[i-1]+2 # if i-2-dp[i-1]>=0:dp[i]+=dp[i-2-dp[i-1]]res=max(res,dp[i]) return res

2.LeetCode-300 最长上升子序列–长度

题目:给定一个无序的整数数组,找到其中最长上升子序列的长度。

输入: [10,9,2,5,3,7,101,18]
输出: 4 
解释: 最长的上升子序列是 [2,3,7,101],它的长度是 4

dp[i] --以nums[i]结尾的,上升序列的长度中,最长的一个。

def lengthOfLIS(self, nums):""":type nums: List[int]:rtype: int"""# dp[i]表示以nums[i]为结尾的最长上升子序列的长度n = len(nums)if n < 2:return ndp = [1] * nres = 0for i in range(1,n):for j in range(i):if nums[j]< nums[i]:dp[i] = max(dp[i], dp[j]+1)res = max(res, dp[i])               # 这么写就需要考虑初值为1的时候return res

2.维度d


3.LeetCode-32 最长回文子串–是什么

独自一个人也,也可以二维dp, 强!二维dp实际上也是以每个字符为中心向两边扩展的情况。
dp[i][j] 表示s[i]-s[j]子串是否是回文子串,依赖于s[i]==s[j] and dp[i+1][j-1]
状态转移决定了dp初始化元素(对角线)和更新的方向(由下向上,由对角线往右)

def longestPalindrome(self, s):n = len(s)if n < 2:          # 空字符和单个字符直接输出return sdp = [[False] * n for _ in range(n)]for i in range(n):dp[i][i] = Trueres_str, res_len = s[0], 1    # 两个字符的的时候,不相等时结果为单个字符for i in range(n-2,-1,-1):for j in range(i+1, n):if j == i+1:          # 次对角线上的元素单独判断。if s[i] == s[j]:dp[i][j] = Trueif j-i+1 > res_len:res_str = s[i:j+1]res_len = j - i + 1else:if s[i] == s[j] and dp[i+1][j-1]:dp[i][j] = Trueif j-i+1 > res_len:res_str = s[i:j+1]res_len = j - i + 1return res_str  

5.LeetCode-512 最长回文子序列–长度

和上题的基本思路一样,不过dp数组表示的含义变为
dp[i][j] 表示s[i]-s[j]子串中回文序列的长度

# if s[i]==s[j]:dp[i][j] = dp[i+1][j-i]+2,
# if s[i]!=s[j]:dp[i][j] = max(dp[i+1][j],dp[i][j-1])
def longestPalindromeSubseq(self, s):n = len(s)if n < 2:return ndp = [[0] * n for _ in range(n)]for i in range(n):dp[i][i] = 1for i in range(n-2, -1, -1):for j in range(i+1,n):if s[j] == s[i]:dp[i][j] = dp[i+1][j-1] + 2else:dp[i][j] = max(dp[i+1][j], dp[i][j-1])return dp[0][n-1]

6.LeetCode-1143 最长公共子序列–长度

(两个字符串,二维dp 才是标配嘛)
dp[i][j] 表示s1[0]-s1[i] 于s2[0]-s2[j] 的最长公共子序序列,更新形式于512题类似,只不过初值和方向不大一样,初值为第0行第0列均为0,方向由上到下,由左到右。

def longestCommonSubsequence(self, text1, text2):l1, l2 = len(text1), len(text2)dp = [[0] * (l2 + 1) for _ in range(l1 + 1)]for i in range(1, l1 + 1):for j in range(1, l2 + 1):if text1[i-1] == text2[j-1]:dp[i][j] = dp[i-1][j-1] + 1else:dp[i][j] = max(dp[i-1][j], dp[i][j-1])# return dp[-1][-1]#  回溯 只有加res_str=[""]*dp[-1][-1]i,j=l1,l2while(i>0):if dp[i][j]>dp[i-1][j]:                   # 比上面的大,不是来上面if dp[i][j]>dp[i][j-1]:				  # 	比左边的大,不是来自左边res_str[dp[i][j]-1]=text1[i-1]    # 		来自对角线操作else:                                 # 	没有左边大,来自左边 横坐标操作i+=1							  # 		i 需要先+1,最后的-1会抵消j-=1								  # 	没有左边大,来自左边,纵坐标操作i-=1print(res_str)

3.带技巧解题


6.LeetCode-128 最长连续序列–长度

给定一个未排序的整数数组,找出最长连续序列的长度。要求算法的时间复杂度为 O(n)。

数组本身无序,连续序列有序,只要能找到连续序列的开头,就能确定序列长度,迭代更新最长长度就可以了。

def longestConsecutive(self, nums):if not nums:return 0res = 1nums_set = set(nums)for val in nums_set:if val - 1 not in nums_set:     # val 为连续序列的开头count = 1num = valwhile(num + 1 in nums_set):count += 1num = num + 1res = max(res, count)return res

7.LeetCode-14 最长公共前缀-字符串

暴力法:纵向扫描
先验:最长公共前缀不回比最短的字符串长,所以先求出最短的长度。

def longestCommonPrefix(self, strs):""":type strs: List[str]:rtype: str"""n = len(strs)if n == 0:return ""min_l = float("INF")for string in strs:min_l = min(len(string), min_l)i = 0con_pre = ""while(i < min_l):con_pre = strs[0][:i+1]for string in strs:if string[:i+1] != con_pre:return con_pre[:i]i += 1return con_pre

8.剑指offer-48 最长不含重复字符串的子字符串-长度

请从字符串中找出一个最长的不包含重复字符的子字符串,计算该最长子字符串的长度。

输入: "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3

移动窗口,保证窗口内的字符无重复,如果有重复就缩小窗口。

def lengthOfLongestSubstring(self, s):""":type s: str:rtype: int"""win = {}left, right = 0, 0n = len(s)res = 0while (right < n):c1 = s[right]if win.get(c1):win[c1] += 1else:win[c1]  = 1right += 1while(win[c1]>1):c2 = s[left]win[c2] -=1left += 1res  = max(res, right - left)return res

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

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

相关文章

一个简单的游戏服务器框架 .

最近一段时间不是很忙&#xff0c;就写了一个自己的游戏服务器框架雏形&#xff0c;很多地方还不够完善&#xff0c;但是基本上也算是能够跑起来了。我先从上层结构说起&#xff0c;一直到实现细节吧&#xff0c;想起什么就写什么。 第一部分 服务器逻辑 服务器这边简单的分为三…

游戏登陆流程 .

当公司有很多游戏的时候&#xff0c;那么公司往往会有一个统一的账号管理平台&#xff0c;就就像盛大通行证、网易通行证&#xff0c;战网平台&#xff0c;这些平台统一管理游戏的账号数据。 打个比方&#xff0c;现在我们玩星辰变&#xff0c;那么玩家登陆游戏的时候…

leetcode97 交错字符串

给定三个字符串 s1, s2, s3, 验证 s3 是否是由 s1 和 s2 交错组成的。 示例 1: 输入: s1 "aabcc", s2 "dbbca", s3 "aadbbcbcac" 输出: true 示例 2: 输入: s1 "aabcc", s2 "dbbca", s3 "aadbbbaccc" 输…

算法(27)-最大系列

最大系列1.LeetCode-239 滑动窗口的最大值2.LeetCode-53 连续子数组的最大和3.LeetCode-152 乘积最大的子数组。4.剑指 Offer 14- I. 剪绳子为k个整数段&#xff0c;使各个段成绩最大1.dp数学推导1.LeetCode-239 滑动窗口的最大值 窗口由左往右最大值数组Left&#xff0c;和由…

mysql数据库表的导入导出

MySQL写入数据通常用insert语句&#xff0c;如 复制代码 代码如下: insert into person values(张三&#xff0c;20)&#xff0c;&#xff08;李四&#xff0c;21&#xff09;&#xff0c;&#xff08;王五&#xff0c;70&#xff09;…; 但有时为了更快速地插入大批量数据或…

leetcode 33 搜索旋转排序数组 到处是细节的好题

这个题想了想就会做&#xff0c;只是细节真的能卡死人&#xff0c;找了好久的bug。甚至我怀疑我现在的代码可能还有错&#xff0c;只是没例子测出来。 假设按照升序排序的数组在预先未知的某个点上进行了旋转。 ( 例如&#xff0c;数组 [0,1,2,4,5,6,7] 可能变为 [4,5,6,7,0,1…

多线程中局部静态变量初始化的陷阱

C当中常常需要一个全局唯一的对象实例&#xff0c;这时候&#xff0c;我们就会想到单件模式。如何实现这一模式&#xff1f;全局变量当然是一个简单可行的方法&#xff0c;然而&#xff0c;这太丑陋。嗯&#xff0c;其实&#xff0c;丑陋倒也罢了&#xff0c;最严重的是它将引诱…

MachineLearning(8)-PCA,LDA基础+sklearn 简单实践

PCA,LDA基础sklearn 简单实践1.PCAsklearn.decomposition.PCA1.PCA理论基础2.sklearn.decomposition.PCA简单实践2.LDAsklearn.discriminant_analysis.LinearDiscriminantAnalysis2.1 LDA理论基础2.2 sklearn LDA简单实践1.PCAsklearn.decomposition.PCA 1.PCA理论基础 PCA:&…

引用变量和引用数组

前两天没事干,重拾C++的一些书籍,翻到引用这,无意写了些DD: 其实引用和指针有很多相似的地方,又有不同的(太多了,不过说到效率上,比如函数传参数,我们可以用引用,指针,哪种好呢,引用不必为站再分配空间了,而指针还学要分配4字节的空间给指针变量) 我们知道如何…

leetcode198 打家劫舍

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋。每间房内都藏有一定的现金&#xff0c;影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚上被小偷闯入&#xff0c;系统会自动报警。 给定一个代表每个房屋存放金额的…

linux下的RPC

一、概述 在传统的编程概念中&#xff0c;过程是由程序员在本地编译完成&#xff0c;并只能局限在本地运行的一段代码&#xff0c;也即其主程序和过程之间的运行关系是本地调用关系。因此这种结构在网络日益发展的今天已无法适应实际需求。总而言之&#xff0c;传统过程调用模式…

算法(28)--矩阵搜索系列

矩阵搜索1.leetcode-200. 岛屿数量2.leetcode-695. 岛屿的最大面积3.leetcode-463. 岛屿的周长4.剑指 Offer 12. 矩阵中的路径5.leetcode-329. 矩阵中的最长递增路径6.leetcode-1091. 二进制矩阵中的最短路径1.leetcode-200. 岛屿数量 给你一个由 ‘1’&#xff08;陆地&#…

leetcode213 打家劫舍II

你是一个专业的小偷&#xff0c;计划偷窃沿街的房屋&#xff0c;每间房内都藏有一定的现金。这个地方所有的房屋都围成一圈&#xff0c;这意味着第一个房屋和最后一个房屋是紧挨着的。同时&#xff0c;相邻的房屋装有相互连通的防盗系统&#xff0c;如果两间相邻的房屋在同一晚…

linux下安装boost

以下是在ubuntu 7.10 (内核 2.6.22-14)下安装的例子&#xff1a; 一、下载最新的 boost 库&#xff0c;下载地址&#xff1a; http://www.boost.org/users/download/ 二、在适当的位置解压 boost 库&#xff0c;推荐把 boost 库解压到 /usr/local/ 下&#xff1a; $ cd dowlo…

PaperNotes(4)-高质量图像生成-CGAN-StackGAN-Lapgan-Cyclegan-Pix2pixgan

cgan,stackgan,lapgan,cyclegan,pix2pixgan1.Conditional GAN1.1简介1.2网络结构与训练1.3特点与用途2.Stack GAN2.1简介2.2网络结构与训练2.3特点与用途3.Lap GAN3.1简介3.2网络结构与训练3.3特点与用途4.Pix2pix GAN4.1 简介4.2 网络结构和训练4.3 特点和用途5.Patch GAN6.Cy…

关于c++的一些案例

之前做项目的时候,有时候会用到位,也就是将一些数据放在二进制里,然后存在数据库中或者缓存在服务器上,取出来,然后要判断某位是不是置0或1,然后再将某位置0或1(比如领多个奖励的 游戏逻辑),之前有点傻,竟然用 << ,>>这些运算符计算,今天翻起以前好久不…

C++(1)--概况、开发工具、hello word

简介1. 概况2. 开发工具3. mac 写hello word4. c 基本概念5.两个数相加代码分解5.1编译预处理命令# include5.2输入输出库iostream6.注释7.编码规范《老九学堂C课程》《C primer》学习笔记。《老九学堂C课程》详情请到B站搜索《老九零基础学编程C入门》1. 概况 20世纪70年代&a…

class 和 struct的区别

C中的struct对C中的struct进行了扩充&#xff0c;它已经不再只是一个包含不同数据类型的数据结构了&#xff0c;它已经获取了太多的功能。 struct能包含成员函数吗&#xff1f; 能&#xff01; struct能继承吗&#xff1f; 能&#xff01;&#xff01; struct能实现多态吗&…

leetcode206 反转链表

反转一个单链表。 示例: 输入: 1->2->3->4->5->NULL 输出: 5->4->3->2->1->NULL 进阶: 你可以迭代或递归地反转链表。你能否用两种方法解决这道题&#xff1f; 经典题不解释 /*** Definition for singly-linked list.* public class ListNode…

浅议柔性数组

很多时候,柔性数组应用在了变长结构体中,如: StructPacket {Int state; Int len;