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
