mfc 找到字符串中字符_利用滑动窗口解LeetCode438题:找到字符串中所有字母异位词...
生活随笔
收集整理的這篇文章主要介紹了
mfc 找到字符串中字符_利用滑动窗口解LeetCode438题:找到字符串中所有字母异位词...
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目描述(難度中等)
給定一個(gè)字符串 s 和一個(gè)非空字符串 p,找到 s 中所有是 p 的字母異位詞的子串,返回這些子串的起始索引。
字符串只包含小寫英文字母,并且字符串 s 和 p 的長(zhǎng)度都不超過 20100。
說明:
字母異位詞指字母相同,但排列不同的字符串。
不考慮答案輸出的順序。
示例 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" 的字母異位詞。解題思路
利用滑動(dòng)窗口:
- 窗口的長(zhǎng)度是p的長(zhǎng)度
- 用兩個(gè)哈希數(shù)組存儲(chǔ)p的字母情況和滑動(dòng)窗口的字母情況。如果二者相同,則將起始位置加入到結(jié)果中,如果不同,則將滑動(dòng)窗口右移一位繼續(xù)判斷。
代碼如下
class Solution { public:vector<int> findAnagrams(string s, string p) {vector<int> res;if(s.size()<p.size())//邊界情況return res;int pn=p.size();vector<int> hash_p(256,0);//兩個(gè)哈希數(shù)組存儲(chǔ)p和滑動(dòng)窗口的字母vector<int> hash_temp(256,0);for(auto c:p)//將p的字母存儲(chǔ)起來hash_p[c]++;int left=0;//滑動(dòng)窗口的左指針for(int i=0;i<s.size();i++){if(i<pn)//第一個(gè)滑動(dòng)窗口{hash_temp[s[i]]++;//如果s的前p.size()字母正好是p的字母異位詞,將起始位置0加入結(jié)果if(i==pn-1 && hash_p==hash_temp)res.push_back(0); }else{int k=i-pn;hash_temp[s[k]]--;//減去移動(dòng)窗口后的前一個(gè)位置的字母hash_temp[s[i]]++;//加上窗口右移后新加入的字母left++;//窗口起始位置+1//如果是異位詞,則將起始位置加入結(jié)果if(hash_temp==hash_p)res.push_back(left);}}return res;} };提交結(jié)果:
總結(jié)
以上是生活随笔為你收集整理的mfc 找到字符串中字符_利用滑动窗口解LeetCode438题:找到字符串中所有字母异位词...的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python默认参数 可变对象_当心Py
- 下一篇: reactor线程模型_从TCP服务器到