leedcode刷题--day8

28 最长回文子串

在这里插入图片描述
采用动态规划的方式

  1. 首先如果子串长度为1的话,一定是回文子串
  2. 如果子串长度为2,那如果第一个字母=第二个字母,即为回文子串
  3. 如果bababd中babab为回文子串,那么除去左边界和右边界后的也是回文子串
class Solution(object):def longestPalindrome(self, s):""":type s: str:rtype: str"""n = len(s)if n < 2:return smax_len = 1begin = 0# 数组dp = [[False] * n for _ in range(n)]# 如果 i=i 一定是for i in range(n):dp[i][i] = Truefor L in range(2, n+1): #L表示当前回文子串长度for i in range(n): #当前的索引j = L + i - 1 #终止索引if j >= n:breakif s[i] != s[j]:dp[i][j] = Falseelse:if j - i < 2:dp[i][j] = Trueelse:dp[i][j] = dp[i+1][j-1]  if dp[i][j] and j - i + 1 > max_len:max_len = j - i + 1begin = ireturn s[begin:begin+max_len]
class Solution {
public:string longestPalindrome(string s) {int n = s.length();if(n<2){return s;}int maxLen = 1;int begin = 0;vector<vector<int>>dp(n,vector<int>(n));for (int i = 0;i<n;i++){dp[i][i]=true;}for (int L = 2;L<=n;L++){for (int i=0;i<n;i++){int j = L+i-1;if(j>=n){break;}if(s[i]!=s[j]){dp[i][j]=false;}else{if(j-i<3){dp[i][j]=true;}else{dp[i][j] = dp[i+1][j-1];}}if (dp[i][j] && (j-i+1)>maxLen){maxLen = j-i+1;begin =i;}}}return s.substr(begin,maxLen);}
};

29 二叉树

在这里插入图片描述

# Definition for a binary tree node.
# class TreeNode:
#     def __init__(self, val=0, left=None, right=None):
#         self.val = val
#         self.left = left
#         self.right = right
class Solution:def buildTree(self, preorder: List[int], inorder: List[int]) -> Optional[TreeNode]:#当前序遍历的左边界大于右边界时,说明当前子树为空,直接返回 Nonedef myBuildTree(preorder_left:int,preorder_right:int,inorder_left:int,inorder_right:int):if preorder_left>preorder_right:return None #前序遍历第一个节点即为根节点preorder_root = preorder_left#在中序遍历中定位根节点inorder_root = index[preorder[preorder_root]]#先把根节点建立出来root = TreeNode(preorder[preorder_root])#得到左子树节点数目size_left_subtree = inorder_root-inorder_left#递归构造左子树,并连接到根结点root.left = myBuildTree(preorder_left + 1, preorder_left + size_left_subtree, inorder_left, inorder_root - 1)root.right = myBuildTree(preorder_left + size_left_subtree + 1, preorder_right, inorder_root + 1, inorder_right)return rootn = len(preorder)index = {element: i for i,element in enumerate(inorder)}return myBuildTree(0,n-1,0,n-1)
  1. 首先,先序遍历是中左右,中序是左中右
  2. 然后根结点是先序的第一个,中序得到根节点的位置,然后看根节点左边和右边各几个节点。
  3. 建立二叉树
class Solution {
private:unordered_map<int, int> index;public:TreeNode* myBuildTree(const vector<int>& preorder, const vector<int>& inorder, int preorder_left, int preorder_right, int inorder_left, int inorder_right) {if (preorder_left > preorder_right) {return nullptr;}// 前序遍历中的第一个节点就是根节点int preorder_root = preorder_left;// 在中序遍历中定位根节点int inorder_root = index[preorder[preorder_root]];// 先把根节点建立出来TreeNode* root = new TreeNode(preorder[preorder_root]);// 得到左子树中的节点数目int size_left_subtree = inorder_root - inorder_left;// 递归地构造左子树,并连接到根节点// 先序遍历中「从 左边界+1 开始的 size_left_subtree」个元素就对应了中序遍历中「从 左边界 开始到 根节点定位-1」的元素root->left = myBuildTree(preorder, inorder, preorder_left + 1, preorder_left + size_left_subtree, inorder_left, inorder_root - 1);// 递归地构造右子树,并连接到根节点// 先序遍历中「从 左边界+1+左子树节点数目 开始到 右边界」的元素就对应了中序遍历中「从 根节点定位+1 到 右边界」的元素root->right = myBuildTree(preorder, inorder, preorder_left + size_left_subtree + 1, preorder_right, inorder_root + 1, inorder_right);return root;}TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {int n = preorder.size();// 构造哈希映射,帮助我们快速定位根节点for (int i = 0; i < n; ++i) {index[inorder[i]] = i;}return myBuildTree(preorder, inorder, 0, n - 1, 0, n - 1);}
};

30 无重复字符的最长子串

在这里插入图片描述
要找出一个字符串中不含重复字符的最长子串的长度,可以使用滑动窗口算法。具体步骤如下:

  1. 定义一个哈希表 char_index_map 用来存储字符及其在字符串中最后出现的位置。
  2. 使用双指针 left 和 right 表示滑动窗口的左右边界,初始时两者都指向字符串开头。
  3. 不断移动右指针 right,同时更新哈希表中字符的最新位置。
  4. 如果发现当前字符在哈希表中已经存在,说明出现了重复字符,需要移动左指针 left 到重复字符的下一个位置。
  5. 在移动过程中不断更新最长子串的长度。
class Solution:def lengthOfLongestSubstring(self, s: str) -> int:char_index_map={}max_length = 0left = 0#这里是字典,就是存储字符和它的位置for right in range(len(s)):#如果当前字符在char_index_map中,说明遇到了重复字符if s[right] in char_index_map:left = max(left,char_index_map[s[right]]+1)char_index_map[s[right]] = rightmax_length = max(max_length,right-left+1)return max_length

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

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

相关文章

ping和telnet的区别

ping是ICMP协议&#xff0c;只包含控制信息没有端口&#xff0c;用于测试两个网络主机之间网络是否畅通 telnet是TCP协议&#xff0c;用于查看目标主机某个端口是否开发。 总结&#xff1a;ping是物理计算机间的网络互通检查&#xff0c;telnet是应用服务间的访问连通检查&am…

应对磁盘管理挑战:Linux磁盘分区挂载命令实践指南

前言 在今天的技术世界中&#xff0c;Linux已成为广泛使用的操作系统之一&#xff0c;而对于运维人员和开发人员来说&#xff0c;磁盘分区挂载是一个至关重要的任务。正确地管理和配置磁盘分区挂载可以极大地提升系统的性能和可靠性&#xff0c;同时也能确保数据的安全性。 通…

18. UE5 RPG初始化角色的属性

在7. UE5 RPG修改GAS的Attribute的值中&#xff0c;我们创建AS的时候&#xff0c;也设置了默认值&#xff0c;但是这种方法是在初始化AS的时候创建的&#xff0c;无法进行个性化定义&#xff0c;因为我们创建的所有的角色的属性不可能相同&#xff0c;所以&#xff0c;我们需要…

解锁区块链游戏数据解决方案

作者&#xff1a;stellafootprint.network 随着区块链技术的日新月异&#xff0c;游戏行业正迎来一场革命&#xff0c;催生了区块链游戏的崛起。这一变革不仅为用户带来了全新的互动体验&#xff0c;也开辟了全新的盈利渠道。然而&#xff0c;在这一新兴领域&#xff0c;数据的…

计算机系统基础 2 Intel 中央处理器

Intel微处理器的发展史 INTegrated ELectronics&#xff08;集成电子&#xff09;的缩写 先后推出的中央处理器&#xff1a; Intel4004、Intel8008、Intel8080/8085、8086/8088、80186、80286、i386、i486 Pentium&#xff08;奔腾&#xff09;、Pentium II、Pentium III、Pen…

力扣● 583. 两个字符串的删除操作 ● 72. 编辑距离 ● 编辑距离总结篇

● 583. 两个字符串的删除操作 注意审题&#xff1a; 给定两个单词 word1 和 word2 &#xff0c;返回使得 word1 和 word2 相同所需的最小步数。 每步 可以删除任意一个字符串中的一个字符。 删除最少的字符使两者相同&#xff0c;说明留下来的就是最大公共子序列。不要求…

字符串知识1 (strcmp,strncmp,strstr)

L1-070 吃火锅 参考了一下网上的代码&#xff0c;学到了三种字符串函数&#xff1a; 1.strncmp(const char* str1, const char* str2, int num) 若在规定长度 n 内两个字符串相同&#xff0c;返回 0 &#xff1b;否则比较第一个不同位置上的字符的ASCII码&#xff0c;返回 -…

tomcat 实现会话绑定

Tomcat 后端服务器实现 Session ID会话保持 基础架构&#xff1a; 7-6 代理服务器nginx配置 7-3 tomcat 服务器 7-5 同理 测试&#xff1a; 此时刷新&#xff0c;会话ID一直在变&#xff0c;这样不好 如何解决呢&#xff1f; 不好的是确定ip之后&#xff0c;会一直在一台机上…

docker实战(3)

1, jdk17版本的dockerfile FROM eclipse-temurin:17-jre ADD ./target/ods-poc-0.0.1-SNAPSHOT.jar /home/app/app.jar WORKDIR /home/app ENV TZ Asia/Shanghai ENTRYPOINT ["java","-jar","/home/app/app.jar"] EXPOSE 8083dockerfile 1, …

“技多不压身”是什么意思?看完这篇文章你会明白:有了手艺,走遍天下都不怕!

“技多不压身”是什么意思&#xff1f;看完这篇文章你会明白&#xff1a;有了手艺&#xff0c;走遍天下都不怕&#xff01; 咱们的老祖宗流传一句话&#xff1a;“一招鲜&#xff0c;吃遍天。”这话说得直白&#xff0c;却道出了学一门手艺或技术对于人生的重要性。“李秘书讲…

HarmonyOS NEXT应用开发—状态栏显隐变化

介绍 本示例介绍使用Scroll组件的滚动事件 onScroll 实现状态栏显隐变化。该场景多用于各种软件的首页、我的等页面中。 效果预览图 使用说明 加载完成后显示状态栏显隐变化页面&#xff0c;上下拖动屏幕&#xff0c;顶端状态栏出现显隐变化。 实现思路 在置顶位置使用sta…

查询ES之细化需求实现多字段、范围过滤、加权和高亮

多字段查询和过滤 一次从两个字段中查询同一个搜索词&#xff0c;比如从title和content中进行查询&#xff0c;另外指定active字段的值必须为true&#xff08;一般代表该文档未被删除或隐藏&#xff09;&#xff1a; GET /docwrite2/_search { "query": { "…