★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:爲敢(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
中只有小寫英文字母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 }
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 }