给定一个字符串和一个字符串字典,找到字典里面最长的字符串,该字符串可以通过删除给定字符串的某些字符来得到。如果答案不止一个,返回长度最长且字典顺序最小的字符串。如果答案不存在,则返回空字符串。
示例 1:
输入: s = "abpcplea", d = ["ale","apple","monkey","plea"] 输出: "apple"
示例 2:
输入: s = "abpcplea", d = ["a","b","c"] 输出: "a"
说明:
- 所有输入的字符串只包含小写字母。
- 字典的大小不会超过 1000。
- 所有输入的字符串长度不会超过 1000。
解题思路:
子序列判断,特殊排序。如果s删除一定的字符之后会变成d中单词,那么这个单词就是s的子序列。
- 遍历所有单词,查找满足条件的单词,即该单词是s的子序列。
- 得到所有子序列之后,找到最长的,如果最长有多个,返回字典序最小的。
class Solution { public: string findLongestWord(string s, vector<string>& d) { int size = d.size(), i; if (size == 0) return ""; vector<string> res; for (i = 1; i <= size; i++) { if (isSub(d[i - 1], s)) res.push_back(d[i - 1]); } if (res.empty()) return ""; sort(res.begin(), res.end(), Solution::cmp); return res[0]; } static bool cmp(string a,string b) { if (a.size() == b.size()) return a < b; return a.size() > b.size(); } bool isSub(string sub, string data) {//检测sub是否是data的子序列 int size_s = sub.size(), size_d = data.size(), pos_s = 0, pos_d = 0; while (pos_s < size_s) { if (pos_d >= size_d) return false; if (sub[pos_s] == data[pos_d]) { pos_s++; pos_d++; } else pos_d++; } return true; } }; |