力扣hot100【滑动窗口】

3.无重复字符的最长子串

双指针维护无重复字符的区间,更新长度。

c++ 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        unordered_map<char,int>mp; 
        int n=s.size();
        int ans=0;
        for(int i=0,j=0;j<n;j++){
            mp[s[j]]++;
            while(mp[s[j]]>1){
                mp[s[i]]--;
                i++;
            }
            ans=max(ans,j-i+1);
        }
        return ans;
    }
};

438.找到字符串中所有字母异位词

字母异位词,长度相等。以目的字符串为长度去原串中遍历,双指针维护长度,cnt数组统计字符出现次数

c++ 复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        int n=s.size();
        int m=p.size();
        array<int, 26> cnt_p{}; 
        array<int, 26> cnt_s{};
        vector<int>ans;
        for(char c:p){
            cnt_p[c-'a']++;
        }
        for(int i=0;i<n;i++){
            cnt_s[s[i]-'a']++;
            if(i-m+1<0){
                continue;
            }
            if(cnt_p==cnt_s){
                ans.push_back(i-m+1);
            }
            cnt_s[s[i-m+1]-'a']--;
        }
        return ans; 
    }
};
相关推荐
CQU_JIAKE1 小时前
5.7【A】
算法
2zcode1 小时前
基于SVM与HOG算法的行人检测系统设计与实现
算法·机器学习·支持向量机
MATLAB代码顾问1 小时前
MATLAB实现粒子群算法优化PID参数
开发语言·算法·matlab
翎沣1 小时前
C++11异常处理机制
java·c++·算法
火花怪怪1 小时前
Origin分析外量子效率(EQE, External Quantum Efficiency)数据处理-EQE计算带隙
算法·数据分析
上弦月-编程2 小时前
异或法巧解数组中两独数
数据结构·算法
risc1234562 小时前
维特比算法(Viterbi Algorithm)
算法
Black蜡笔小新2 小时前
自动化AI算法训练服务器/企业AI算力工作站DLTM重塑企业AI开发模式赋能企业智能转型
人工智能·算法·自动化