day19(力扣)3的幂、最小差值Ⅰ(python描述)

题目描述:给定一个整数,写一个函数来判断它是否是 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)

这类题主要就是分析好题目的要求,他的考察点也就在这里,然后按照题目的要求进行编写代码就好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值