日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

Leetcode双指针滑动窗口相关题目

發(fā)布時(shí)間:2025/4/5 编程问答 16 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Leetcode双指针滑动窗口相关题目 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

滑動(dòng)窗口

滑動(dòng)窗口解決哪種問(wèn)題?
滑動(dòng)窗口解決給定兩個(gè)字符串S和T,問(wèn)你S中是否存在一個(gè)子串,包含T中的所有字符并且不含有其他字符。

窗口右指針向右移動(dòng),窗口增大,直到滿足條件,這時(shí)候找到可行解。
窗口左指針開(kāi)始往右移動(dòng),窗口減小,開(kāi)始搜尋最優(yōu)解。

滑動(dòng)窗口的代碼邏輯:偽代碼

int left = 0, right = 0;while (right < s.size()) {//增大窗口window.add(s[right]);right++;while (window needs shrink) {//縮小窗口window.remove(s[left]);left++;}}

滑動(dòng)窗口的代碼框架

偽代碼

void slidingWindow(string s, string t) {unordered_map<char, int> window, need;for(char c:t) need[c]++;//統(tǒng)計(jì)字符個(gè)數(shù)int left = 0, right = 0;int valid = 0;//窗口中滿足need條件的字符個(gè)數(shù)while (right < s.size()) {//c是將移入窗口的字符char c = s[right];//右移窗口right++;//進(jìn)行窗口內(nèi)數(shù)據(jù)的一系列更新...//debug 輸出的位置cout << "window: " << left << " " << right << endl;//判斷左側(cè)窗口是否要收縮while (window needs shrink) {//d是將要移出窗口的字符char d = s[left];//左移窗口left++;//進(jìn)行窗口內(nèi)一系列更新...}} }

解釋:unordered_map 是哈希表,實(shí)現(xiàn)鍵(key)值(value)映射,它的一個(gè)方法是count(key) 判斷鍵key是否存在。

unordered_map<char, int> window, need;

window和need是計(jì)數(shù)器

  • window記錄窗口中字符的個(gè)數(shù)
  • need記錄所需要的字符長(zhǎng)度
  • 下面valid表示need中字符被滿足的個(gè)數(shù),比如need中字符a的數(shù)量有2個(gè),在window中字符a的數(shù)量≥2時(shí),valid的值會(huì)自增valid++。

    當(dāng)valid==need.size() 的時(shí)候,證明字符串t中字符個(gè)數(shù)已滿足,window左指針開(kāi)始右移,進(jìn)行窗口縮減。

    使用滑動(dòng)窗口模板解題

    Leetcode76 最小覆蓋子串

    給你一個(gè)字符串 S、一個(gè)字符串 T,請(qǐng)?jiān)谧址?S 里面找出:包含 T 所有字母的最小子串。

    示例:

    輸入: S = “ADOBECODEBANC”, T = “ABC”
    輸出: “BANC”

    說(shuō)明:

    如果 S 中不存這樣的子串,則返回空字符串 “”。
    如果 S 中存在這樣的子串,我們保證它是唯一的答案。

    來(lái)源:力扣(LeetCode)
    鏈接:https://leetcode-cn.com/problems/minimum-window-substring
    著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。
    代碼

    class Solution { public:string minWindow(string s, string t) {if(s.size()<t.size()) return "";//t中包含的字符更多unordered_map<char,int> window,need;for(int i=0;i<t.size();i++)//need哈希表初始化need[t[i]]++;int left=0,right=0;//前后指針int valid=0;//記錄字符匹配的個(gè)數(shù)int start=0,len=INT_MAX;//最小字串的起始點(diǎn),和長(zhǎng)度while(right<s.size()){//右指針char p=s[right];//p在子串t中if(need.count(p)){window[p]++;if(window[p]==need[p])valid++;}right++;//確保右區(qū)間是開(kāi)的,即左閉右開(kāi),方便計(jì)算right-left長(zhǎng)度while(valid==need.size()){//滿足最低個(gè)數(shù)要求,window中元素個(gè)數(shù)≥need中元素個(gè)數(shù)if(right-left<len){//最小覆蓋子串len=right-left;start=left;}char q=s[left];//從窗口中除去left++;if(need.count(q)){if(window[q]==need[q])valid--;window[q]--; }}}return len==INT_MAX ?"":s.substr(start,len);} };

    Leetcode567 字符串的排列

    給定兩個(gè)字符串 s1 和 s2,寫(xiě)一個(gè)函數(shù)來(lái)判斷 s2 是否包含 s1 的排列。
    換句話說(shuō),第一個(gè)字符串的排列之一是第二個(gè)字符串的子串。
    示例1:

    輸入: s1 = “ab” s2 = “eidbaooo”
    輸出: True
    解釋: s2 包含 s1 的排列之一 (“ba”).

    示例2:

    輸入: s1= “ab” s2 = “eidboaoo”
    輸出: False

    注意:

    輸入的字符串只包含小寫(xiě)字母
    兩個(gè)字符串的長(zhǎng)度都在 [1, 10,000] 之間

    來(lái)源:力扣(LeetCode)
    鏈接:https://leetcode-cn.com/problems/permutation-in-string
    著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

    分析
    窗口縮減的時(shí)機(jī)是窗口大小等于 s1.size()時(shí),這是因?yàn)榕帕泻驮址L(zhǎng)度一致。
    當(dāng)valid==need.size()時(shí),子串合法

    代碼

    class Solution { public:bool checkInclusion(string s1, string s2) {unordered_map<char,int> window,need;for(auto t:s1) need[t]++;int left=0, right=0;int valid=0;while(right<s2.size()){char c=s2[right];if(need.count(c)){window[c]++;if(window[c]==need[c]){valid++;}}right++;while(right-left>=s1.size()){if(valid==need.size())return true;char d=s2[left];if(need.count(d)){if(need[d]==window[d]){valid--;}window[d]--;}left++;}}return false;} };

    Leetcode438. 找到字符串中所有字母異位詞

    給定一個(gè)字符串 s 和一個(gè)非空字符串 p,找到 s 中所有是 p 的字母異位詞的子串,返回這些子串的起始索引。

    字符串只包含小寫(xiě)英文字母,并且字符串 s 和 p 的長(zhǎng)度都不超過(guò) 20100。

    說(shuō)明:

    字母異位詞指字母相同,但排列不同的字符串。 不考慮答案輸出的順序。

    示例 1:

    輸入:
    s: “cbaebabacd” p: “abc”

    輸出:
    [0, 6]

    解釋:
    起始索引等于 0 的子串是 “cba”, 它是 “abc” 的字母異位詞。
    起始索引等于 6 的子串是 “bac”, 它是 “abc” 的字母異位詞。

    示例 2:

    輸入:
    s: “abab” p: “ab”

    輸出:
    [0, 1, 2]

    解釋:
    起始索引等于 0 的子串是 “ab”, 它是 “ab” 的字母異位詞。
    起始索引等于 1 的子串是 “ba”, 它是 “ab” 的字母異位詞。
    起始索引等于 2 的子串是 “ab”, 它是 “ab” 的字母異位詞。

    來(lái)源:力扣(LeetCode)
    鏈接:https://leetcode-cn.com/problems/find-all-anagrams-in-a-string
    著作權(quán)歸領(lǐng)扣網(wǎng)絡(luò)所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系官方授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

    分析
    異位詞就是上面的排列,這里只需要更改返回符合條件的子串的下標(biāo)

    代碼

    class Solution { public:vector<int> findAnagrams(string s, string p) {if(s.size()==0) return {};vector<int> vec;unordered_map<char,int> need,window;for(int i=0;i<p.size();i++)need[p[i]]++;int left=0,right=0;int valid=0;while(right<s.size()){char c=s[right];if(need.count(c)){window[c]++;if(need[c]==window[c])valid++;}right++;while(right-left>=p.size()){if(valid==need.size()){vec.push_back(left);}char d=s[left];left++;if(need.count(d)){if(need[d]==window[d])valid--;window[d]--;}}}return vec;} };

    補(bǔ)充窗口簡(jiǎn)單題

    Problem Description
    有一個(gè)字符串S,該字符串只含有小寫(xiě)字母a-z,長(zhǎng)度不大于100。

    現(xiàn)在需要在S中尋找它的一個(gè)子字符串str,且str至少在S中出現(xiàn)過(guò)兩次(字符串可以部分重疊,但是不能和子字符串str串完全重疊)。

    計(jì)算一下這個(gè)子字符串str的最大長(zhǎng)度是多少。

    Input
    輸入一行字符串S(字符串的長(zhǎng)度不大于100)

    Output
    輸出子字符串str的最大長(zhǎng)度

    Sample Input:
    ababa

    Sample Output:
    3

    #include<iostream> #include<map> #include<string> #include<cstdlib>//exit()using namespace std;map<string,int> mp; string s; int cnt;int main(){cin>>s;int len=s.size();int left=0,right=len-1;//倒數(shù)第二個(gè)字符 for(int i=len-1;i>0;i--){//控制長(zhǎng)度 while(left<len&&left+i<=len){string tmp=s.substr(left,i);//長(zhǎng)為i //cout<<tmp<<endl;mp[tmp]++;if(mp[tmp]>=2){cout<<i; exit(0);} left++;//窗口右移 } left=0;//窗口位置 }return 0; }

    總結(jié)

    以上是生活随笔為你收集整理的Leetcode双指针滑动窗口相关题目的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    主站蜘蛛池模板: 激情内射人妻1区2区3区 | 欧美bbbbb| 自拍偷拍视频网站 | 欧美精品999 | 中文字幕乱码中文乱码b站 国产一区二区三区在线观看视频 | 成人里番精品一区二区 | 天天艹夜夜艹 | 性高潮久久久久久久 | 久久综合激的五月天 | 国产伦理片在线观看 | 人人爱人人澡 | 午夜精品久久久久久久91蜜桃 | 秋霞视频一区二区 | 中文字幕在线观看视频免费 | 大黄网站在线观看 | av在线天堂 | 自拍偷拍第一页 | 成人午夜性视频 | 中文字幕第二区 | 成人欧美一区二区三区黑人免费 | 欧美激情91 | 日本老熟妇毛茸茸 | 草草久久久| 国产视频一区二区不卡 | 97影视 | 女厕厕露p撒尿八个少妇 | 久久91| 91九色porny视频 | 日韩 国产| 久久久久久91香蕉国产 | 精品无码三级在线观看视频 | 亚洲无码久久久久久久 | 久草视频在线观 | av午夜天堂 | 日本高清黄色电影 | 91嫩草香蕉 | av在线免费不卡 | 久久免费视频99 | www亚洲色图 | 伊人自拍视频 | 国产又大又黑又粗免费视频 | 精品一区免费 | 91精品国产99久久久久久 | 国产精品久久午夜夜伦鲁鲁 | 国产三级国产精品国产专区50 | 性高潮久久久久久 | 宅男av在线 | 精品久久9999 | 学生孕妇videosex性欧美 | 蜜臀在线一区二区三区 | 欧美性猛交一区二区三区精品 | 亚州中文字幕 | 五月婷婷六月婷婷 | 日日操日日干 | 欧美国产精品一二三 | 不卡的毛片 | 爱爱视频网 | 日本一区二区人妻 | 国产91丝袜在线播放九色 | 五月天六月色 | 五月天婷婷视频 | 黄色裸体网站 | 91福利在线导航 | jizjiz中国少妇高潮水多 | 日本一道在线 | av导航在线 | 日批在线观看视频 | jjzzjjzz欧美69巨大| 波多野42部无码喷潮在线 | 久久r| 青青草成人影视 | 欧美三级大片 | 秋霞网av| 国产91欧美 | 五月婷婷激情网 | 中文字幕av一区二区三区人妻少妇 | 在线综合视频 | 免费网站观看www在线观看 | www.日韩.com | 亚洲国产精品一区二区久久hs | 五月天丁香社区 | 可乐操亚洲| 国产伦精品一区二区三区免费 | 亚洲成a人片77777精品 | 公妇借种乱htp109cc | av免播放器在线观看 | 狠狠干b | av不卡在线播放 | 日韩国产成人在线 | 美女福利视频在线 | 特黄aaaaaaaaa真人毛片 | 打屁股疼的撕心裂肺的视频 | 久久aⅴ国产欧美74aaa | 干欧美| 成人在线免费高清视频 | 俺去俺来也在线www色官网 | 国产精品.xx视频.xxtv | 福利视频网站 | 亚洲免费三级 |