46 leetcode - 如何快速判断一个数是不是2的幂、3的幂、4的幂
来源:互联网 发布:mac装excel图表插件 编辑:程序博客网 时间:2024/06/03 20:20
判断一个数是不是2的幂
#!/usr/bin/python# -*- coding: utf-8 -*-'''Power of TwoGiven an integer, write a function to determine if it is a power of two.判断一个数是否等于pow(2,n).如果一个数等于pow(2,n),则2进制表达中,有且仅有一个1。n & (n-1) == 0'''class Solution(object): def isPowerOfTwo(self, n): """ :type n: int :rtype: bool """ if n <= 0: return False return True if n&(n-1) == 0 else False
判断一个数是不是4的幂
4的幂首先是2的幂,因为4^n = (2^2)^n,所以4的幂的二进制同样只有一个1,与2的幂不同的是,4的幂的二进制的1在奇数位上,所以判断一个数是不是4的幂的方式为:
1)首先判断是不是2的幂,使用 n & (n-1)
2)进一步判断与0x55555555的按位与结果,0x55555555是用十六进制表示的数,其奇数位上全是1,偶数位上全是0,判断 n & 0x55555555
class Solution(object): def isPowerOfFour(self, num): """ :type num: int :rtype: bool """ if num <= 0: return False if num & (num - 1) != 0: return False return False if num & 0x55555555 == 0 else True
判断一个数是不是3的幂
'''Power of ThreeGiven an integer, write a function to determine if it is a power of three.判断一个数是否等于pow(3,n).'''class Solution(object): def isPowerOfThree(self, n): """ :type n: int :rtype: bool """ if n <= 0: return False max_3_pow = 0 while pow(3,max_3_pow + 1) <= n: max_3_pow += 1 return True if n == pow(3,max_3_pow) else False
还有一种很机智的方法,我们首先分析3的幂的特点,假设一个数Num是3的幂,那么所有Num的约数都是3的幂,如果一个数n小于Num且是3的幂,那么这个数n一定是Num的约数。
了解上述性质,我们只需要找到一个最大的3的幂,看看参数n是不是此最大的幂的约数就行了.
class Solution(object): ''' 找到一个最大的3的幂 a = pow(2,31) - 1,最大的正整数 import math math.log(a,3),19.5588223603 最大的3的幂 = pow(3,19) = 1162261467 ''' def isPowerOfThree(self, n): """ :type n: int :rtype: bool """ if n <= 0: return False return True if 1162261467%n == 0 else False
参考链接:http://blog.csdn.net/x_i_y_u_e/article/details/50507281
0 0
- 46 leetcode - 如何快速判断一个数是不是2的幂、3的幂、4的幂
- 如何快速判断一个数是不是2的幂、3的幂、4的幂
- 如何快速判断一个数是不是2的幂、3的幂、4的幂
- 如何快速判断一个数是不是2的幂、3的幂、4的幂
- 快速的判断一个数是不是2,3,4的幂
- 如何判断一个数是不是2的n次幂
- 判断一个数是不是2的幂
- 判断一个数是不是2的幂
- 判断一个数是不是2的幂
- 如何快速判断一个数是不是 2 的乘方?
- 如何快速判断一个数是不是2的n次方
- [LeetCode-231] Power of Two(判断一个数是不是2的若干次幂)
- LeetCode刷题: power of two (判断一个数是不是2的幂次方)
- 判断一个数是不是2的幂次
- 判断一个数是不是2的n次幂...
- 算法 - 判断一个数是不是2的n次幂
- UVa11254 - Consecutive Integers(判断一个数是不是2的幂)
- 判断一个数是不是2的整数次幂
- 十年•杭研技术秀 | iOS APP的加固保护原理
- Java String.split()处理分隔符
- H5智能内核-基于MVC架构的全新Zoomla!逐浪CMS2 x3.8发布
- android 7.0 + 相机拍照 FileUriExposedException
- DOS查看端口号,并关闭占用端口的进程
- 46 leetcode - 如何快速判断一个数是不是2的幂、3的幂、4的幂
- Struts2 本地化/国际化实现
- VS2013无法加载解决方案中的项目
- LXC(Linux containers)快速入门
- js RegExp二次匹配异常
- window.opener 与 window.dialogArguments的用法
- AS2.2使用Butterknife8.4(8.x)遇到的坑。
- 箭头函数(一)
- 竖排导航