★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★
➤微信公衆號:山青詠芝(shanqingyongzhi)
➤博客園地址:山青詠芝(https://www.cnblogs.com/strengthen/)
➤GitHub地址:https://github.com/strengthen/LeetCode
➤原文地址: http://www.javashuo.com/article/p-vsdovgaj-me.html
➤若是連接不是山青詠芝的博客園地址,則多是爬取做者的文章。
➤原文已修改更新!強烈建議點擊原文地址閱讀!支持做者!支持原創!
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★html
Let's say a positive integer is a superpalindrome if it is a palindrome, and it is also the square of a palindrome.git
Now, given two positive integers L
and R
(represented as strings), return the number of superpalindromes in the inclusive range [L, R]
. github
Example 1:微信
Input: L = "4", R = "1000" Output: 4 Explanation: 4, 9, 121, and 484 are superpalindromes. Note that 676 is not a superpalindrome: 26 * 26 = 676, but 26 is not a palindrome.
Note:app
1 <= len(L) <= 18
1 <= len(R) <= 18
L
and R
are strings representing integers in the range [1, 10^18)
.int(L) <= int(R)
若是一個正整數自身是迴文數,並且它也是一個迴文數的平方,那麼咱們稱這個數爲超級迴文數。spa
如今,給定兩個正整數 L
和 R
(以字符串形式表示),返回包含在範圍 [L, R]
中的超級迴文數的數目。 code
示例:htm
輸入:L = "4", R = "1000" 輸出:4 解釋: 4,9,121,以及 484 是超級迴文數。 注意 676 不是一個超級迴文數: 26 * 26 = 676,可是 26 不是迴文數。
提示:blog
1 <= len(L) <= 18
1 <= len(R) <= 18
L
和 R
是表示 [1, 10^18)
範圍的整數的字符串。int(L) <= int(R)
1 class Solution { 2 let value:[Int] = [0, 1, 4, 9, 121, 484, 676, 10201, 12321, 14641, 40804, 44944, 69696, 94249, 698896, 1002001, 1234321, 3 4008004, 5221225, 6948496, 100020001, 102030201, 104060401, 121242121, 123454321, 125686521, 400080004, 4 404090404, 522808225, 617323716, 942060249, 10000200001, 10221412201, 12102420121, 12345654321, 5 40000800004, 637832238736, 1000002000001, 1002003002001, 1004006004001, 1020304030201, 1022325232201, 6 1024348434201, 1086078706801, 1210024200121, 1212225222121, 1214428244121, 1230127210321, 1232346432321, 7 1234567654321, 1615108015161, 4000008000004, 4004009004004, 4051154511504, 5265533355625, 9420645460249, 8 100000020000001, 100220141022001, 102012040210201, 102234363432201, 121000242000121, 121242363242121, 9 123212464212321, 123456787654321, 123862676268321, 144678292876441, 165551171155561, 400000080000004, 10 900075181570009, 4099923883299904, 10000000200000001, 10002000300020001, 10004000600040001, 10020210401202001, 11 10022212521222001, 10024214841242001, 10201020402010201, 10203040504030201, 10205060806050201, 12 10221432623412201, 10223454745432201, 12100002420000121, 12102202520220121, 12104402820440121, 13 12120030703002121, 12122232623222121, 12124434743442121, 12321024642012321, 12323244744232321, 14 12341234943214321, 12343456865434321, 12345678987654321, 40000000800000004, 40004000900040004, 94206450305460249] 15 func superpalindromesInRange(_ L: String, _ R: String) -> Int { 16 var l:Int = bound(Int(L) ?? 0) 17 var r:Int = bound(Int(R) ?? 0) 18 var res:Int = 0 19 while(l != r) 20 { 21 var v:Int = value[l] 22 var root:Int = Int(sqrt(Double(v))) 23 var s1:String = String(root) 24 var s2:String = String(s1.reversed()) 25 if s2 == s1 26 { 27 res += 1 28 } 29 l += 1 30 } 31 return res 32 } 33 34 func bound(_ target:Int) -> Int 35 { 36 var low = 0 37 var high = value.count - 1 38 var mid = (low + high) >> 1 39 40 while low <= high { 41 let val = value[mid] 42 if target == val { 43 return mid 44 } else if target < val { 45 high = mid - 1 46 } else { 47 low = mid + 1 48 } 49 mid = (low + high) >> 1 50 } 51 return low 52 } 53 }
Time Limit Exceeded索引
1 class Solution { 2 func superpalindromesInRange(_ L: String, _ R: String) -> Int { 3 var l:Int = Int(L) ?? 0 4 var r:Int = Int(R) ?? 0 5 var result:Int = 0 6 var i:Int = Int(sqrt(Double(l))) 7 while(i * i <= r) 8 { 9 var p:Int = nextP(i) 10 if p * p <= r && isP(p * p) 11 { 12 result += 1 13 } 14 i = p + 1 15 } 16 return result 17 } 18 19 func nextP(_ l:Int) -> Int 20 { 21 var s:String = String(l) 22 var len:Int = s.count 23 var cands:[Int] = [Int]() 24 let num:Int = Int(pow(10, Double(len))) - 1 25 cands.append(num) 26 var half:String = s.subString(0, (len + 1) / 2) 27 let num0:Int? = Int(half) 28 var nextHalf:String = String(1) 29 if num0 != nil 30 { 31 nextHalf = String(num0! + 1) 32 } 33 var reverse:String = String(half.subString(0, len / 2).reversed()) 34 var nextReverse:String = String(nextHalf.subString(0, len / 2).reversed()) 35 let num1:Int? = Int(half + reverse) 36 if num1 != nil 37 { 38 cands.append(num1!) 39 } 40 let num2:Int? = Int(nextHalf + nextReverse) 41 if num2 != nil 42 { 43 cands.append(num2!) 44 } 45 var result:Int = Int.max 46 for i in cands 47 { 48 if i >= l 49 { 50 result = min(result, i) 51 } 52 } 53 return result 54 } 55 56 func isP(_ l:Int) -> Bool 57 { 58 var arrS:[Character] = Array(String(l)) 59 var i:Int = 0 60 var j:Int = arrS.count - 1 61 while (i < j) 62 { 63 if arrS[i] != arrS[j] 64 { 65 return false 66 } 67 i += 1 68 j -= 1 69 } 70 return true 71 } 72 } 73 74 extension String { 75 // 截取字符串:指定索引和字符數 76 // - begin: 開始截取處索引 77 // - count: 截取的字符數量 78 func subString(_ begin:Int,_ count:Int) -> String { 79 let start = self.index(self.startIndex, offsetBy: max(0, begin)) 80 let end = self.index(self.startIndex, offsetBy: min(self.count, begin + count)) 81 return String(self[start..<end]) 82 } 83 }