[Swift]LeetCode395. 至少有K個重複字符的最長子串 | Longest Substring with At Least K Repeating Characters

原文地址:http://www.javashuo.com/article/p-xayaxhfo-e.html html

Find the length of the longest substring T of a given string (consists of lowercase letters only) such that every character in T appears no less than k times.數組

Example 1:app

Input:
s = "aaabb", k = 3

Output:
3

The longest substring is "aaa", as 'a' is repeated 3 times. 

Example 2:less

Input:
s = "ababbc", k = 2

Output:
5

The longest substring is "ababb", as 'a' is repeated 2 times and 'b' is repeated 3 times.

找到給定字符串(由小寫字符組成)中的最長子串 T , 要求 T 中的每一字符出現次數都很多於 k 。輸出 的長度。函數

示例 1:spa

輸入:
s = "aaabb", k = 3

輸出:
3

最長子串爲 "aaa" ,其中 'a' 重複了 3 次。

示例 2:code

輸入:
s = "ababbc", k = 2

輸出:
5

最長子串爲 "ababb" ,其中 'a' 重複了 2 次, 'b' 重複了 3 次。

16ms
 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3         guard s.count > 0 else {
 4             return 0
 5         } 
 6         
 7         guard k > 0 else {
 8             return s.count
 9         }
10         
11         var result = Int.min
12         var sArray = s.map{ String($0) }
13         
14         func splitString(string: [String]) {
15             guard string.count > 0 else {
16                 return
17             }
18             var memo = [String: Int]()
19             var invalidChar = [String]()
20             for i in 0..<string.count {
21                 memo[string[i]] = memo[string[i], default:0] + 1
22             }
23 
24             var candidates = [[String]]()
25             var last = -1
26             var i = 0
27             while i < string.count  {
28                 if memo[string[i]]! < k {
29                     if i <= last + 1 {
30                         last = i
31                         i += 1
32                         continue
33                     } else {
34                         candidates.append(Array(string[last + 1..<i]))
35                         last = i
36                     }
37                 }
38                 i += 1
39             }
40             
41             if last < string.count - 1{
42                 candidates.append(Array(string[last + 1..<string.count]))
43             }
44             
45             if last == -1 {
46                 result = max(string.count, result)
47                 return
48             }
49             
50             for c in candidates {
51                 splitString(string:c)
52             }
53         }
54         
55         splitString(string:sArray)
56         return result == Int.min ? 0 : result
57     }
58 }

20mscomponent

 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3         return helper(Array(s), 0, s.count, k)
 4     }
 5     
 6     func helper(_ s: [Character], _ left: Int, _ right: Int, _ k: Int) -> Int {
 7         guard right - left >= k else { return 0 }
 8         var counts = [Character: Int]()
 9         for char in s[left..<right] {
10             counts[char] = (counts[char] ?? 0) + 1
11         }
12         
13         for i in left..<right where counts[s[i]]! < k {
14             var j = i + 1
15             while j < right && counts[s[j]]! < k { j += 1 }
16             return max(helper(s, left, i, k), helper(s, j, right, k))
17         }
18         return right - left
19     }
20 }

52mshtm

 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3         var arr = Array(s)
 4         var cmap:[Character:Int] = [:]
 5         
 6         if s.length == 0 {
 7             return 0
 8         }
 9         
10         for c in arr {
11             if cmap[c] == nil {
12                 cmap[c] = 0
13             }
14             cmap[c] = cmap[c]! + 1
15         }
16         
17         var leastfreq = arr.count+1
18         var leastfreqchar:Character? = nil
19         for (letter, count) in cmap {
20             if count < leastfreq {
21                 leastfreq = count
22                 leastfreqchar = letter
23             }
24         }
25         
26         if leastfreq >= k {
27             return s.count
28         }        
29         
30         var begin = 0
31         var maxsofar = 0
32         for i in 0...arr.count {
33             if i == arr.count || arr[i] == leastfreqchar {
34                 let tmp = Array(arr[begin..<i])
35                 let tmps:String = String(tmp)
36                 maxsofar = max(maxsofar, longestSubstring(tmps, k))
37                 begin = i+1
38             }
39         }
40         
41         return maxsofar
42     }
43 }

56msblog

 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3         if k <= 1 { return s.count }
 4         
 5         let array = [Character](s)
 6         var dict = [Character: Int]()
 7         for c in array {
 8             if let count = dict[c] {
 9                 dict[c] = count + 1
10             } else {
11                 dict[c] = 1
12             }
13         }
14         
15         var result = 0
16         var separator: Character? = nil
17         for key in dict.keys {
18             if let count = dict[key], count < k {
19                 separator = key
20                 break
21             }
22         }
23         if let separator = separator {
24             let subStringArray = s.components(separatedBy: String(separator))
25             for subString in subStringArray {
26                 let temp = longestSubstring(subString, k)
27                 if temp > result {
28                     result = temp
29                 }
30             }
31         } else {
32             return s.count
33         }
34         return result
35     }
36 }

764ms

 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3       if s.count < k {
 4         return 0
 5     }
 6     var dict = [Character: Int]()
 7     var i = 0
 8     var j = 0
 9     let ss = Array(s)
10     var maxLength = 0
11     for k in s {
12         dict[k] = (dict[k] ?? 0) + 1
13     }
14     let dict2 = dict.filter{$0.value < k}
15     if dict2.count == 0 {
16         return s.count
17     }
18     while j < s.count {
19         if let d = dict2[ss[j]] {
20             if d < k {
21                 let start = s.index(s.startIndex, offsetBy: i)
22                 let end = s.index(s.startIndex, offsetBy: j)
23                 let range = start..<end
24                 let subS = s[range]
25                 maxLength = max(maxLength, longestSubstring(String(subS), k))
26                 i = j + 1
27             }
28         }
29         j += 1
30     }
31     let start = s.index(s.startIndex, offsetBy: i)
32     let end = s.index(s.startIndex, offsetBy: j)
33     let range = start..<end
34     let subS = s[range]
35     maxLength = max(maxLength, longestSubstring(String(subS), k))
36     return maxLength
37     }
38 }

948ms

 1 class Solution {
 2     func longestSubstring(_ s: String, _ k: Int) -> Int {
 3         var n:Int = s.count
 4         var max_idx:Int = 0
 5         var res:Int = 0     
 6         var m:[Int] = [Int](repeating:0,count: 128)
 7         var ok:Bool = true
 8         for c in s.characters
 9         {
10             m[c.ascii] += 1
11         }
12         for i in 0..<n
13         {
14             if m[s[i].ascii] < k
15             {
16                 res = max(res, longestSubstring(s.subString(max_idx, i - max_idx), k))
17                 ok = false
18                 max_idx = i + 1
19             }
20         }
21         return ok ? n : max(res, longestSubstring(s.subString(max_idx, n - max_idx), k)) 
22     }
23 }
24 
25 extension String {        
26     //subscript函數能夠檢索數組中的值
27     //直接按照索引方式截取指定索引的字符
28     subscript (_ i: Int) -> Character {
29         //讀取字符
30         get {return self[index(startIndex, offsetBy: i)]}
31     }
32     
33     // 截取字符串:指定索引和字符數
34     // - begin: 開始截取處索引
35     // - count: 截取的字符數量
36     func subString(_ begin:Int,_ count:Int) -> String {
37         let start = self.index(self.startIndex, offsetBy: max(0, begin))
38         let end = self.index(self.startIndex, offsetBy:  min(self.count, begin + count))
39         return String(self[start..<end]) 
40     }
41 }
42 
43 //Character擴展方法  
44 extension Character  
45 {  
46   //屬性:ASCII整數值(定義小寫爲整數值)
47    var ascii: Int {
48         get {
49             let s = String(self).unicodeScalars
50             return Int(s[s.startIndex].value)
51         }
52     }
53 }
相關文章
相關標籤/搜索