给你一个字符串 s
和一个字符串数组 dictionary
,找出并返回 dictionary
中最长的字符串,该字符串可以通过删除 s
中的某些字符得到。
如果答案不止一个,返回长度最长且字母序最小的字符串。如果答案不存在,则返回空字符串。
示例 1:
输入:s = "abpcplea", dictionary = ["ale","apple","monkey","plea"] 输出:"apple"
示例 2:
输入:s = "abpcplea", dictionary = ["a","b","c"] 输出:"a"
提示:
1 <= s.length <= 1000
1 <= dictionary.length <= 1000
1 <= dictionary[i].length <= 1000
s
和dictionary[i]
仅由小写英文字母组成
function findLongestWord(s: string, dictionary: string[]): string {
dictionary.sort((a, b) => {
if (a.length === b.length) {
return b < a ? 1 : -1;
}
return b.length - a.length;
});
const n = s.length;
for (const target of dictionary) {
const m = target.length;
if (m > n) {
continue;
}
let i = 0;
let j = 0;
while (i < n && j < m) {
if (s[i] === target[j]) {
j++;
}
i++;
}
if (j === m) {
return target;
}
}
return '';
}
impl Solution {
pub fn find_longest_word(s: String, mut dictionary: Vec<String>) -> String {
dictionary.sort_unstable_by(|a, b| (b.len(), a).cmp(&(a.len(), b)));
for target in dictionary {
let target: Vec<char> = target.chars().collect();
let n = target.len();
let mut i = 0;
for c in s.chars() {
if i == n {
break;
}
if c == target[i] {
i += 1;
}
}
if i == n {
return target.iter().collect();
}
}
String::new()
}
}