Leetcode笔记目录
一、题目描述
给定一个字符串和一个字符串字典,找到字典里面最长的字符串,该字符串可以通过删除给定字符串的某些字符来得到。如果答案不止一个,返回长度最长且字典顺序最小的字符串。如果答案不存在,则返回空字符串。
示例1:
- 输入: s = “abpcplea”, d = [“ale”,“apple”,“monkey”,“plea”]
输出: “apple”
示例2:
- 输入: s = “abpcplea”, d = [“a”,“b”,“c”]
输出: “a”
二、解题过程
1.思想
双指针,同时扫描字符串和字典中的字符串,若扫描完后字典字符串全部在字符串s中,则满足条件,然后sort排序即可:
2.代码
string findLongestWord(string s, vector<string>& d) {
vector<string> c;
for(int i=0;i<d.size();i++){
int l=0;
for(int j=0;j<s.size();j++){
if(s[j]==d[i][l])l++;
}
if(l==d[i].size())c.push_back(d[i]);
}
sort(c.begin(),c.end(),[](string a,string b){return a.size()==b.size()?a<b:a.size()>b.size();});
if(c.size()!=0)return c[0];
return "";
}
三、总结
一次做对,比较简单。