Leetcode:524. 通过删除字母匹配到字典里最长单词

给定一个字符串和一个字符串字典,找到字典里面最长的字符串,该字符串可以通过删除给定字符串的某些字符来得到。如果答案不止一个,返回长度最长且字典顺序最小的字符串。如果答案不存在,则返回空字符串。

示例 1:

输入:
s = "abpcplea", d = ["ale","apple","monkey","plea"]

输出: 
"apple"

示例 2:

输入:
s = "abpcplea", d = ["a","b","c"]

输出: 
"a"

说明:

  1. 所有输入的字符串只包含小写字母。
  2. 字典的大小不会超过 1000。
  3. 所有输入的字符串长度不会超过 1000。

解题思路:

子序列判断,特殊排序。如果s删除一定的字符之后会变成d中单词,那么这个单词就是s的子序列。

  1. 遍历所有单词,查找满足条件的单词,即该单词是s的子序列。
  2. 得到所有子序列之后,找到最长的,如果最长有多个,返回字典序最小的。

C++代码
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;
    }
};

猜你喜欢

转载自blog.csdn.net/qq_23523409/article/details/85093559