常见且相似的leetcode题目

一、无重复字符的最长子串(子串需要连续)

题目描述:给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
例子:
输入: s = “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。

思路:
利用哈希表,遍历字符串s,若字母之前未出现,则将其下标保存起来,若该字母在前面出现时,获取其下标并计算长度(此时为不重复的子串长度),接着更新起始的子串下标。

class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int n=s.length();
        int ans=0;
        int pre=0;//记录答案子串的起始下标
        unordered_map<char,int>mp;//存放字母以及下标
        int i=0;
        for(;i<n;i++){
            if(mp.find(s[i])==mp.end()){//未出现,则保存
                mp.emplace(s[i],i);
            }
            else{
                int k=mp[s[i]];//得到其下标
                mp[s[i]]=i;
                if(k>=pre&&ans<i-pre){
                    ans=i-pre;
                }
                pre=max(pre,k+1);   //更新起始下标
            }
        }
        if(ans<i-pre){
            ans=i-pre;
        }
        return ans;
    }
};

二、不同字符的最小子序列(字典序)

题目描述:返回 s 字典序最小的子序列,该子序列包含 s 的所有不同字符,且只包含一次。
例子:
输入:s = “cbacdcbc”
输出:“acdb”

class Solution {
public:
    string smallestSubsequence(string s) {
        int n=s.length();
        vector<int>num(26,0);//记录s中各个元素的个数
        vector<int>vis(26,0);//判断某一字符是否已经进入
        string temp;
        for(int i=0;i<n;i++){
            num[s[i]-'a']++;
        }
        for(int i=0;i<n;i++){
            if(!vis[s[i]-'a']){
                while(!temp.empty()&&s[i]<temp.back()){
                    if(num[temp.back()-'a']>0){
                        vis[temp.back()-'a']=0;
                        temp.pop_back();
                    }
                    else{
                        break;
                    }
                }
                temp.push_back(s[i]);
                vis[s[i]-'a']=1;//已存放在栈里
            }
            num[s[i]-'a']--;
        }
       return temp;
    }
};

三、最长公共子序列(不需要连续)(典型二维dp)

题目描述:
给定两个字符串 text1 和 text2,返回这两个字符串的最长 公共子序列 的长度。如果不存在 公共子序列 ,返回 0 。
一个字符串的 子序列 是指这样一个新的字符串:它是由原字符串在不改变字符的相对顺序的情况下删除某些字符(也可以不删除任何字符)后组成的新字符串。
例子:
输入:text1 = “abcde”, text2 = “ace”
输出:3
解释:最长公共子序列是 “ace” ,它的长度为 3 。

思路:
在这里插入图片描述当text1[i]==text2[j]时,dp[i][j]=dp[i-1][j-1]
当text1[i]!=text2[j]时,dp[i][j]=max(d[i-1][j],dp[i][j-1])

class Solution {
public:
    int longestCommonSubsequence(string text1, string text2) {
        int n1=text1.length();
        int n2=text2.length();
        int dp[1002][1002];
        for(int i=0;i<=n1;i++){//初始化时要留意
            dp[i][0]=0;
        }
        for(int i=0;i<=n2;i++){
            dp[0][i]=0;
        }
        for(int i=1;i<=n1;i++){
            for(int j=1;j<=n2;j++){
                if(text1[i-1]==text2[j-1]){
                    dp[i][j]=dp[i-1][j-1]+1;
                }
                else{
                    dp[i][j]=max(dp[i][j-1],dp[i-1][j]);
                }
            }
        }
        return dp[n1][n2];
    }
};

四、KMP算法

class Solution {
public:
    void CreateNext(vector<int>&nextval,string needle){
        int k=-1;
        int j=0;
        nextval[0]=-1;
        while(j<needle.length()-1){
            if(k==-1||needle[j]==needle[k]){
                j++;
                k++;
         //当a位与其next[a]的字符相等时,让next[a]=next[next[a]]
                if(needle[j]!=needle[k]){
                    nextval[j]=k;
                }
                else{
                    nextval[j]=nextval[k];
                }
            }
            else{
                k=nextval[k];
            }
        }
    }
    int strStr(string haystack, string needle) {
        int  n1=haystack.length();
        int n2=needle.length();
        if(n2==0){
            return 0;
        }
        vector<int>nextval(n2,0);
        CreateNext(nextval,needle);
        int i=0,j=0;
        while(i<n1&&j<n2){
            if(j==-1||haystack[i]==needle[j]){
                i++;
                j++;
            }
            else{
                j=nextval[j];
            }
        }
        if(j>=n2){
            return i-n2;
        }
        else{
            return -1;
        }
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: LeetCode是一种流行的在线刷题平台,提供了许多算法和数据结构挑战,旨在帮助程序员和计算机科学家提高他们的编程技能。以下是几个LeetCode题目及其答案: 1. 两数之和 题目描述:给定一个整数数组和一个目标值,找出数组中的两个数,它们相加等于目标值。假设每个输入只对应一种答案,并且不能使用相同的元素。 答案:遍历数组,将每个数字存储到一个哈希表中,同时计算出目标值与当前数字的差值。如果差值在哈希表中,则返回这两个数字的索引。时间复杂度为O(n)。 2. 盛最多水的容器 题目描述:给定n个非负整数a1,a2,...,an,其中每个点(i,ai)表示一个坐标。画n条垂直线,使得线i的两个端点在(i,ai)和(i,0)上。找到两条线,它们与x轴一起构成一个容器,使得容器中包含最多水。 答案:使用双指针法,分别指向数组的头部和尾部。每次计算当前容器的大小,然后根据容器两侧的高度差决定是否移动指针。时间复杂度为O(n)。 3. 无重复字符的最长子串 题目描述:给定一个字符串,请找出其中不含有重复字符的最长子串的长度。 答案:使用双指针法,分别指向子串的起始和结束位置。每次判断当前字符是否存在于子串中,如果存在,则移动起始指针到重复字符的下一个位置,否则移动结束指针。同时记录最长子串的长度。时间复杂度为O(n)。 上述题目只是LeetCode中的部分题目,不同的题目需要采用不同的算法和数据结构进行解决。通过刷LeetCode和其他类似的在线刷题平台,可以提高编程能力和算法思维能力,使得程序员更加熟练地处理各种算法问题。 ### 回答2: LeetCode是一个在线的编程题库,提供了各种不同难度和类型的编程题目。这些题目主要涵盖了算法、数据结构、字符串操作、图算法等方面的内容。 每道题目都有一个独特的编号和描述,通过阅读题目可以了解到输入和输出的形式,以及题目的具体要求。解答题目通常需要理解问题的本质,设计相应的算法,编写代码实现,并进行测试验证。 题目的难度分为简单、中等和困难三个级别,根据不同的难度以及自己的编程能力,可以选择相应的题目来挑战。 解答题目的关键在于理解问题的本质,分析解决问题的思路,并设计合适的算法实现。这个过程需要对常见的算法和数据结构有一定的了解,比如动态规划、贪心算法、递归、队列等。 对于每一道题目LeetCode提供了多种语言的代码模板,如C++、Java、Python等,可以根据自己的编程习惯和喜好选择相应的语言进行代码编写。 解答题目的过程中需要注意代码的效率和正确性,特别是对于大规模输入的情况,需要考虑时间和空间复杂度。在完成代码编写后,还需要进行测试验证,确保程序的正确性。 在解答题目过程中,可以参考其他人的解题思路和代码实现,并进行对比和学习。LeetCode还提供了题目的讨论区,可以与其他的编程爱好者交流和分享经验。 总之,通过LeetCode可以提升自己的编程能力,加深对算法和数据结构的理解,并为面试和竞赛积累经验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值