438 Find All Anagrams in a String 找符合排列规律的字符串

438 Find All Anagrams in a String 找符合排列规律的字符串

题目:https://leetcode.com/problems/find-all-anagrams-in-a-string/description/

topics: 哈希表 


输入:s: "cbaebabacd" p: "abc"

输出所在位置:[0, 6]


C++:

class Solution {

public:

    vector<int> findAnagrams(string s, string p) {

        vector<int> pv(256,0), sv(256,0), res;

        if(s.size() < p.size())

           return res;

        for(int i = 0; i < p.size(); ++i)

        {

            ++pv[p[i]];

            ++sv[s[i]];

        }

        if(pv == sv)

           res.push_back(0);

        for(int i = p.size(); i < s.size(); ++i)

        {

            ++sv[s[i]];

            --sv[s[i-p.size()]];

            if(pv == sv)

               res.push_back(i-p.size()+1);

        }

        return res;

    }

};