30. Substring with Concatenation of All Words

1.問題

  • 給一個字串, 還有一個字的list, 每個字的長度相同. 找出所有字所拼成的子字串在字串中的起始索引

2.想法

  • 提問

  • function header, parameter

  • test input

  • 說明想法

    • 此題的目的是確認字串中是否有符合目標的子字串: 除了用字串相等外, 可以用範圍內的substr的字串是否有在map中出現, 而且次數相同, 如滿足此條件則將索引push到vector中

    • 用兩個map: 第一個存放string list, 第二個map存放每次移動時, substr中字串所出現的次數

  • 測試計算複雜度: O(n)

3.程式碼

class Solution {
public:
    vector<int> findSubstring(string s, vector<string>& words) {
        vector<int> res;
        int size = words.size(); 
        if (size== 0 || s.empty() || size* words[0].length() > s.length()) {
            return res;
        }
        
        map<string, int> m1;
        for (int i = 0; i < size; i++) {
            m1[words[i]]++;
        }
        
        for (int i = 0 ; i <= s.length() - size * words[0].length(); i++) {
            map<string, int> m2;
            bool flag = true;
            for (int j = 0; j < size; j++) {
                string tmp = s.substr(i + j * words[0].length(), words[0].length());
                if (m1.find(tmp) != m1.end()) {
                    m2[tmp]++;
                } else {
                    flag = false;
                    break;
                }
                
                if (m2[tmp] > m1[tmp]) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                res.push_back(i);
            }
        }
        
        return res;
    }
};

Last updated