[Swift]LeetCode1177. 構建迴文串檢測 | Can Make Palindrome from Substring

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

Given a string s, we make queries on substrings of s.git

For each query queries[i] = [left, right, k], we may rearrange the substring s[left], ..., s[right], and then choose up to k of them to replace with any lowercase English letter. github

If the substring is possible to be a palindrome string after the operations above, the result of the query is true. Otherwise, the result is false.數組

Return an array answer[], where answer[i] is the result of the i-th query queries[i].微信

Note that: Each letter is counted individually for replacement so if for example s[left..right] = "aaa", and k = 2, we can only replace two of the letters.  (Also, note that the initial string s is never modified by any query.)app

 

Example :this

Input: s = "abcda", queries = [[3,3,0],[1,2,0],[0,3,1],[0,3,2],[0,4,1]]
Output: [true,false,false,true,true]
Explanation:
queries[0] : substring = "d", is palidrome.
queries[1] : substring = "bc", is not palidrome.
queries[2] : substring = "abcd", is not palidrome after replacing only 1 character.
queries[3] : substring = "abcd", could be changed to "abba" which is palidrome. Also this can be changed to "baab" first rearrange it "bacd" then replace "cd" with "ab".
queries[4] : substring = "abcda", could be changed to "abcba" which is palidrome.

 

Constraints:spa

  • 1 <= s.length, queries.length <= 10^5
  • 0 <= queries[i][0] <= queries[i][1] < s.length
  • 0 <= queries[i][2] <= s.length
  • s only contains lowercase English letters.

 給你一個字符串 s,請你對 s 的子串進行檢測。code

每次檢測,待檢子串均可以表示爲 queries[i] = [left, right, k]。咱們能夠 從新排列 子串 s[left], ..., s[right],並從中選擇 最多 k 項替換成任何小寫英文字母。 htm

若是在上述檢測過程當中,子串能夠變成迴文形式的字符串,那麼檢測結果爲 true,不然結果爲 false

返回答案數組 answer[],其中 answer[i] 是第 i 個待檢子串 queries[i] 的檢測結果。

注意:在替換時,子串中的每一個字母都必須做爲 獨立的 項進行計數,也就是說,若是 s[left..right] = "aaa" 且 k = 2,咱們只能替換其中的兩個字母。(另外,任何檢測都不會修改原始字符串 s,能夠認爲每次檢測都是獨立的)

 

示例:

輸入:s = "abcda", queries = [[3,3,0],[1,2,0],[0,3,1],[0,3,2],[0,4,1]]
輸出:[true,false,false,true,true]
解釋:
queries[0] : 子串 = "d",迴文。
queries[1] : 子串 = "bc",不是迴文。
queries[2] : 子串 = "abcd",只替換 1 個字符是變不成迴文串的。
queries[3] : 子串 = "abcd",能夠變成迴文的 "abba"。 也能夠變成 "baab",先從新排序變成 "bacd",而後把 "cd" 替換爲 "ab"。
queries[4] : 子串 = "abcda",能夠變成迴文的 "abcba"。

 

提示:

  • 1 <= s.length, queries.length <= 10^5
  • 0 <= queries[i][0] <= queries[i][1] < s.length
  • 0 <= queries[i][2] <= s.length
  • s 中只有小寫英文字母

Runtime: 1204 ms
Memory Usage: 55.4 MB
 1 class Solution {
 2     func canMakePaliQueries(_ s: String, _ queries: [[Int]]) -> [Bool] {
 3         var s:[Int] = Array(s).map{$0.ascii}
 4         var n:Int = s.count
 5         var m:Int = queries.count
 6         var res:[Bool] = [Bool](repeating:false,count:m)
 7         var sum:[[Int]] = [[Int]](repeating:[Int](repeating:0,count:26),count:n)
 8         for i in 0..<n
 9         {
10             if i > 0
11             {
12                 sum[i] = sum[i-1]
13             }
14             sum[i][s[i] - 97] += 1
15         }
16         for i in 0..<m
17         {
18             var l:Int = queries[i][0]
19             var r:Int = queries[i][1]
20             var k:Int = queries[i][2]
21             var cnt:Int = 0
22             for j in 0..<26
23             {
24                 var tmp:Int = sum[r][j]
25                 if l > 0
26                 {
27                     tmp -= sum[l-1][j]
28                 }
29                 
30                 if tmp & 1 != 0
31                 {
32                     cnt += 1
33                 }
34             }
35             if (r-l+1) & 1 != 0
36             {
37                 cnt -= 1
38             }
39             res[i] = cnt <= k * 2
40         }
41         return res
42     }
43 }
44 
45 //Character擴展 
46 extension Character  
47 {  
48   //Character轉ASCII整數值(定義小寫爲整數值)
49    var ascii: Int {
50        get {
51            return Int(self.unicodeScalars.first?.value ?? 0)
52        }       
53     }
54

1328ms

 

 1 class Solution {
 2     func canMakePaliQueries(_ s: String, _ queries: [[Int]]) -> [Bool] {
 3         let s = Array(s.utf8)
 4         var freqs = [Freq]()
 5         var freq = Freq()
 6         freqs.append(freq)
 7         for char in s {
 8             let f = Freq(freq, char)
 9             freqs.append(f)
10             freq = f
11         }
12         
13         var res = [Bool]()
14         for query in queries {
15             res.append(solve(query, freqs))
16         }
17         
18         return res
19     }
20     
21     func solve(_ query: [Int], _ freqs: [Freq]) -> Bool {
22         let freq1 = freqs[query[0]]
23         let freq2 = freqs[query[1] + 1]
24         let num = query[2]
25         let freq = freq1 - freq2
26         var countOdd = 0
27         for i in 0..<26 {
28             if freq.arr[i] % 2 == 1 {
29                 countOdd += 1
30             }
31         }
32         //print(freq, countOdd, num)
33         return (countOdd - num * 2) <= 1
34     }
35 }
36 
37 struct Freq {
38     var arr: [Int]
39     
40     init() {
41         arr = [Int](repeating: 0, count:  26)
42     }
43     
44     init(_ freq: Freq, _ char: UInt8) {
45         self.arr = freq.arr
46         arr[Int(char) - 97] += 1
47     }
48     
49     init(_ str: [UInt8]) {
50         arr = [Int](repeating: 0, count:  26)
51         for char in str {
52             arr[Int(char) - 97] += 1
53         }
54     }
55     
56     static func -(lhs: Freq, rhs: Freq) -> Freq {
57         var freq = Freq()
58         for i in 0..<26 {
59             freq.arr[i] = rhs.arr[i] - lhs.arr[i]
60         }
61         return freq
62     }
63 }

1452ms

 1 class Solution {
 2     func canMakePaliQueries(_ s: String, _ queries: [[Int]]) -> [Bool] {   
 3         let chars = Array(s), n = chars.count
 4         let table = Array("abcdefghijklmnopqrstuvwxyz")
 5         var freq = [[Int]](repeating: [Int](repeating: 0, count: n+1), count: 26)
 6         for c in 0..<26 {
 7             for i in 0..<n {
 8                 freq[c][i+1] = freq[c][i] + (chars[i] == table[c] ? 1 : 0)
 9             }
10         }
11         var ans = [Bool]()
12         for que in queries {
13             var i = que[0], j = que[1], k = que[2]
14             j += 1
15             var odd_count = 0
16             for c in 0..<26 where (freq[c][j] - freq[c][i])%2 != 0 {
17                 odd_count += 1
18             }
19 
20             let fullfill = (odd_count-1) <= 2*k
21             ans.append(fullfill)
22         }
23         return ans
24     }
25 }
相關文章
相關標籤/搜索