[LeetCode]Power of N
题目:Power of Two
Given an integer, write a function to determine if it is a power of two.
题意:判断一个数是否是2的k次方数。
思路:
2的次方数使用2进制表示则必然只有最高位是1其他都是0;
这样判断一个数最多需要循环32次就能得出结果。
则程序如下:
- bool isPowerOfTwo(int n){
- if (!n)return false;
- while ((n&0x01) != 0x01){//2的次方则只有最高位是1
- n = n >> ;
- }
- return n == ;
- }
但是这样还有循环,如何不使用循环一下子判断出来呢?
思路2:
2的次方使用二进制只有一个1,而是用下面的方法,可以判断一个二进制序列中只有一个1.
n&(n-1);//n-1会将n中从小到大第一个为1的位置变成0,这样就能判断只有一个1的情况。
- bool isPowerOfTwo(int n){
- //2的幂只有一个1,则使用n&(n-1)来统计1的个数
- return n > && !(n & (n - ));
- }
题目:Power of Three
Given an integer, write a function to determine if it is a power of three.
Follow up:
Could you do it without using any loop / recursion?
题意:判断一个数是否是3的k次幂数。
要求:不能使用递归或循环。
思路:
如果可以使用循环,也很简单每次对3求余,就可以了。
- bool isPowerOfThree(int n) {
- while (n >= ){
- if (n % )return false;
- n /= ;
- }
- return n == ;
- }
但是,要求不使用循环或递归。
仔细想想,3的k次幂的数就是,该数的因子只有3,那么使用一个在int范围内最大的3的k次幂的数对给定的数求余,如果为0就说明它是3的k次幂的数。
扩展开来,所有的判断n的k次幂的数都是可以使用这个方法。
- bool isPowerOfThree(int n) {
- //int中3的最大次幂数1162261467
- return n > && !( % n);
- }
题目:Power of Four
Given an integer (signed 32 bits), write a function to check whether it is a power of 4.
Example:
Given num = 16, return true. Given num = 5, return false.
Follow up: Could you solve it without loops/recursion?
题意:判断一个数是否是4的k次幂数。
要求:不能使用递归或循环。
思路:
4的次幂,乍一看好像和2的次幂差不多,能不能用类似的方法来求解呢?
仔细一想肯定发现不能单纯判断一个1来判断4的次幂,为什么呢?因为4的次幂写成2进制,1只会出现奇数的位置上,当然排除1的情况。
那么只需要在判断1是不是在奇数的位置上是不是就可以判断它是不是4的k次幂。
推敲一下发现可行,程序如下:
- bool isPowerOfFour(int n){
- return n > && !(n & (n - )) && ((n & 0x55555555) == n);//0x55555555保证在奇数的位置上的1被保留
- }
思路2:
还有一个思路,4^k - 1 = ?
如果k是偶数,不妨设k = 2;因式分解得到(4 - 1)*(4 + 1);
如果k是奇数,不妨设k = 3;因式分解得到(4 - 1)*(4^2 + 4 + 1);
如果k > 2;不妨设k = 2t,则因式分解得到(4^t - 1)*(4^t + 1)
(4^t - 1)同上面的情况,可以发现总可以分出一个(4 - 1)的因子,所以,4^k - 1 必定会有3的因子。
数学不精,没办法精确证明。
- bool isPowerOfFour(int n){
- return n > && !(n & (n - )) && !((n - )%);
- }
[LeetCode]Power of N的更多相关文章
- [LeetCode] Power of Four 判断4的次方数
Given an integer (signed 32 bits), write a function to check whether it is a power of 4. Example: Gi ...
- [LeetCode] Power of Three 判断3的次方数
Given an integer, write a function to determine if it is a power of three. Follow up:Could you do it ...
- [LeetCode] Power of Two 判断2的次方数
Given an integer, write a function to determine if it is a power of two. Hint: Could you solve it in ...
- LeetCode Power of Four
原题链接在这里:https://leetcode.com/problems/power-of-four/ 题目: Given an integer (signed 32 bits), write a ...
- LeetCode Power of Three
原题链接在这里:https://leetcode.com/problems/power-of-three/ 与Power of Two类似.检查能否被3整除,然后整除,再重复检查结果. Time Co ...
- Leetcode Power of Two
Given an integer, write a function to determine if it is a power of two. 题目意思: 给定一个整数,判断是否是2的幂 解题思路: ...
- Leetcode Power of two, three, four
Given an integer, write a function to determine if it is a power of two. Hint: Could you solve it in ...
- leetcode power(x,n)
class Solution { public: double pow(double x, int n) { double a=1; if(n==0)return 1; if(x==1)return ...
- LeetCode——Power of Two
Description: Given an integer, write a function to determine if it is a power of two. public class S ...
随机推荐
- Vue + TypeScript + Element 搭建简洁时尚的博客网站及踩坑记
前言 本文讲解如何在 Vue 项目中使用 TypeScript 来搭建并开发项目,并在此过程中踩过的坑 . TypeScript 具有类型系统,且是 JavaScript 的超集,TypeScript ...
- Facebook的早期历史
Facemash:谁更有吸引力?Facebook的起源 2003年,当时扎克伯格还是一名哈佛大学的二年级学生,他编写了一个名为Facemash的网站.他利用黑客技术入侵了学校管理部门的网站,并从中 ...
- Spring-Boot:Profile简单示例
//Resources目录下创建 application.properties spring.profiles.active=prod //Resources目录下创建 application-pro ...
- 基于mybatisPlus的特殊字符校验
要实现以下代码前提是导入Mybatis-plus的jar: * @author WENGKAIBO505 */ @Target({ElementType.FIELD, ElementType.METH ...
- 分布式事务TransactionScope所导致几个坑
记录一下,个人见解,欢迎指正 错误: 1.该伙伴事务管理器已经禁止了它对远程/网络事务的支持. (异常来自 HRESULT:0x8004D025)2.事务已被隐式或显式提交,或已终止3.此操作对该事务 ...
- HDU 2147
题意略. 思路: 题中提到的3种操作,一个是将长方形的n减少1,一个是将m减少1,一个是将n和m同时减少1,都是将长方形规模减少的的操作. 现在我们可以知道,(1,1)先手必输:(1,2),(2,1) ...
- C# 本地xml文件进行增删改查
项目添加XML文件:FaceXml.xml,并复制到输出目录 FaceXml.xml <?xml version="1.0" encoding="utf-8&quo ...
- 【管理学】PDCA
- poj2396 Budget 上下界可行流
Budget:http://poj.org/problem?id=2396 题意: 给定一个棋盘,给定每一行每一列的和,还有每个点的性质.求一个合理的棋盘数值放置方式. 思路: 比较经典的网络流模型, ...
- 解决flutter:unable to find valid certification path to requested target 的问题
1.问题 周末在家想搞搞flutter,家里电脑是windows的,按照官网教程一步步安装好以后,创建flutter工程,点击运行,一片红色弹出来,WTF? PKIX path building fa ...