Given an array of string words. Return all strings in words which is substring of another word in any order. 
String words[i] is substring of words[j], if can be obtained removing some characters to left and/or right side of words[j].
Example 1:
Input: words = ["mass","as","hero","superhero"] Output: ["as","hero"] Explanation: "as" is substring of "mass" and "hero" is substring of "superhero". ["hero","as"] is also a valid answer.
Example 2:
Input: words = ["leetcode","et","code"] Output: ["et","code"] Explanation: "et", "code" are substring of "leetcode".
Example 3:
Input: words = ["blue","green","bu"] Output: []
Constraints:
- 1 <= words.length <= 100
- 1 <= words[i].length <= 30
- words[i]contains only lowercase English letters.
- It’s guaranteed that words[i]will be unique.
Solution: Brute Force
Time complexity: O(n^2)
Space complexity: O(1)
C++
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | // Author: Huahua class Solution { public:   vector<string> stringMatching(vector<string>& words) {     vector<string> ans;     const int n = words.size();     for (int i = 0; i < n; ++i)       for (int j = 0; j < n; ++j) {         if (i == j) continue;         if (words[j].find(words[i]) != string::npos) {           ans.push_back(words[i]);           break;         }       }     return ans;   } }; | 
请尊重作者的劳动成果,转载请注明出处!花花保留对文章/视频的所有权利。
如果您喜欢这篇文章/视频,欢迎您捐赠花花。
If you like my articles / videos, donations are welcome.



Be First to Comment