单词替换

在英语中,我们有一个叫做 词根(root) 的概念,可以词根后面添加其他一些词组成另一个较长的单词——我们称这个词为 继承词(successor)。例如,词根 an,跟随着单词 other(其他),可以形成新的单词 another(另一个)。
现在,给定一个由许多词根组成的词典 dictionary 和一个用空格分隔单词形成的句子 sentence。你需要将句子中的所有继承词用词根替换掉。如果继承词有许多可以形成它的词根,则用最短的词根替换它。
你需要输出替换之后的句子。

  • 输入:dictionary = [“cat”,”bat”,”rat”], sentence = “the cattle was rattled by the battery”

  • 输出:”the cat was rat by the bat”

  • 输入:dictionary = [“a”,”b”,”c”], sentence = “aadsfasf absbs bbab cadsfafs”

  • 输出:”a a b c”

1
2
3
4
5
6
7
8
9
10
11
12
var replaceWords = function(dictionary, sentence) {
let arr = sentence.split(' ') , cache = [] , set = new Set(dictionary)
for( let word of arr ){
let has = 0
for( let i = 1 ; i <= word.length ; i ++ ){
let now = word.slice(0,i)
if ( set.has(now) && cache.push(now) && ( has = 1 )) break
}
!has && cache.push(word)
}
return cache.join(' ')
};