题目描述:给定一个整数,写一个函数来判断它是否是 3 的幂次方。
示例 1:
输入: 27
输出: true
示例 2:
输入: 0
输出: false
示例 3:
输入: 9
输出: true
示例 4:
输入: 45
输出: false
分析:由基本的数学常识可以知道,如果一个数是三的幂,那么这个数字对3取余,结果一定为 0 ,我们在每一次进行取余运算之后将该数字除以三,最终如果他是三的幂,那么最后这个数会变成 1,因此我们只需要进行这个判断即可。
class Solution:
def isPowerOfThree(self, n: int) -> bool:
if n == 0:
return False
while n % 3 == 0:
n /= 3
if n == 1:
return True
return False
第二题题目描述:给定一个整数数组 A,对于每个整数 A[i],我们可以选择任意 x 满足 -K <= x <= K,并将 x 加到 A[i] 中。在此过程之后,我们得到一些数组 B。返回 B 的最大值和 B 的最小值之间可能存在的最小差值。
示例 1:
输入:A = [1], K = 0
输出:0
解释:B = [1]
示例 2:
输入:A = [0,10], K = 2
输出:6
解释:B = [2,8]
示例 3:
输入:A = [1,3,6], K = 3
输出:0
解释:B = [3,3,3] 或 B = [4,4,4]
提示:
1 <= A.length <= 10000
0 <= A[i] <= 10000
0 <= K <= 10000
分析:题目要求我们找出最大值与最小值的差值,因此我们需要最小化 max(B) - min(B),也就是分别最小化 max(B) 和最大化 min(B)。max(B) 最小可能为 max(A) - K,因为 max(A) 不可能再变得更小。同样,min(B) 最大可能为 min(A) + K。所以结果 max(B) - min(B) 至少为 ans = (max(A) - K) - (min(A) + K)。
class Solution(object):
def smallestRangeI(self, A, K):
return max(0, min(A) - max(A) - 2 * K)
这类题主要就是分析好题目的要求,他的考察点也就在这里,然后按照题目的要求进行编写代码就好。