[Swift]LeetCode1048.最長字符串鏈 | Longest String Chain

★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址:http://www.javashuo.com/article/p-mdjyzidw-mc.html 
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html

Given a list of words, each word consists of English lowercase letters.git

Let's say word1 is a predecessor of word2 if and only if we can add exactly one letter anywhere in word1to make it equal to word2.  For example, "abc" is a predecessor of "abac".github

A word chain is a sequence of words [word_1, word_2, ..., word_k] with k >= 1, where word_1 is a predecessor of word_2word_2 is a predecessor of word_3, and so on.微信

Return the longest possible length of a word chain with words chosen from the given list of words.app

Example 1:this

Input: ["a","b","ba","bca","bda","bdca"]
Output: 4 Explanation: one of the longest word chain is "a","ba","bda","bdca".

Note:spa

  1. 1 <= words.length <= 1000
  2. 1 <= words[i].length <= 16
  3. words[i] only consists of English lowercase letters.

給出一個單詞列表,其中每一個單詞都由小寫英文字母組成。code

若是咱們能夠在 word1 的任何地方添加一個字母使其變成 word2,那麼咱們認爲 word1 是 word2 的前身。例如,"abc" 是 "abac" 的前身。htm

詞鏈是單詞 [word_1, word_2, ..., word_k] 組成的序列,k >= 1,其中 word_1 是 word_2 的前身,word_2 是 word_3 的前身,依此類推。blog

從給定單詞列表 words 中選擇單詞組成詞鏈,返回詞鏈的最長可能長度。

示例:

輸入:["a","b","ba","bca","bda","bdca"]
輸出:4
解釋:最長單詞鏈之一爲 "a","ba","bda","bdca"。

提示:

  1. 1 <= words.length <= 1000
  2. 1 <= words[i].length <= 16
  3. words[i] 僅由小寫英文字母組成。

204ms

 1 class Solution {
 2     func longestStrChain(_ words: [String]) -> Int {
 3         var wordsByLength = Array(repeating: [String: Int](), count: 17)
 4         
 5         for word in words {
 6             wordsByLength[word.count][word] = 1
 7         }
 8         
 9         var returnValue = 1
10         
11         for i in 1...16 {
12             let keys = wordsByLength[i].keys
13             for word in keys {
14                 for j in 0..<word.count {
15                     var prevKey = word
16                     let index = prevKey.index(prevKey.startIndex, offsetBy: j)
17                     prevKey.remove(at: index)
18                     if let result = wordsByLength[prevKey.count][prevKey] {
19                         let this = result + 1
20                         wordsByLength[word.count][word] = this
21                         returnValue = max(returnValue, this)
22                     }
23                 }
24             }
25         }
26         
27         return returnValue
28     }
29 }

696ms

 1 class Solution {
 2     var result = 1
 3     func longestStrChain(_ words: [String]) -> Int {
 4         guard words.count > 0 else {
 5             return 0
 6         }
 7         var memo = [String: Int]()
 8         var dict = [Int: [String]]()
 9         for word in words {
10             dict[word.count] = dict[word.count, default:[String]()]
11             dict[word.count]!.append(word)
12             memo[word] = 1
13         }
14         var sortedWords = words.sorted(by: {$0.count < $1.count})
15         
16         for word in sortedWords {
17             for i in 0..<word.count {
18                 var chars = Array(word)
19                 chars.remove(at: i)
20                 let last = String(chars)
21                 if let value = dict[last.count], value.contains(last) {
22                     memo[word] = max(memo[word]!, memo[last]! + 1)
23                     result = max(memo[word]!, result)
24                 }
25             }
26         }
27         return result
28     }
29 }

Runtime: 2092 ms
Memory Usage: 21 MB
 1 class Solution {
 2     func longestStrChain(_ words: [String]) -> Int {
 3         var words = words
 4         words.sort(by:{
 5             return $0.count < $1.count
 6         })
 7         let n:Int = words.count
 8         var dp:[Int] = [Int](repeating:0,count:n)
 9         dp[0] = 1
10         for i in 1..<n
11         {
12             dp[i] = 1
13             for j in 0..<i
14             {
15                 if predecessor(words[j], words[i])
16                 {
17                     dp[i] = max(dp[i], dp[j] + 1)
18                 }
19                 
20             }
21         }
22         return dp.max() ?? 0
23     }
24     
25     func predecessor(_ t:String,_ s:String) -> Bool
26     {
27         let m:Int = t.count
28         let n:Int = s.count
29         if m != n - 1 {return false}
30         var cnt:Int = 0
31         var i:Int = 0
32         var j:Int = 0
33         let arrT:[Character] = Array(t)
34         let arrS:[Character] = Array(s)
35         while(i < m && j < n)
36         {
37             if arrT[i] == arrS[j]
38             {
39                 i += 1
40                 j += 1
41             }
42             else
43             {
44                 if cnt > 0 {return false}
45                 cnt += 1
46                 j += 1
47             }
48         }
49         return true
50     }
51 }
相關文章
相關標籤/搜索