LeetCode刷题-重新排序得到2的幂

前言说明

算法学习,日常刷题记录。

题目连接

重新排序得到2的幂

题目内容

给定正整数N,我们按任何顺序(包括原始顺序)将数字重新排序,注意其前导数字不能为零。

如果我们可以通过上述方式得到2的幂,返回true;否则,返回false。

示例1:

输入:1

输出:true

示例2:

输入:10

输出:false

示例3:

输入:16

输出:true

示例4:

输入:24

输出:false

示例5:

输入:46

输出:true

提示:

1 <= N <= 10^9

分析过程

这里介绍两种方法,方法1,直线思维分析,容易理解,但是运行超时,不建议使用;方法2,开辟新思路,运行高效,建议使用。

方法1

思路:先判断一次数字本身是否为2的幂,若是2的幂,直接返回true,结束程序;否则,通过不断对10取余和除以10获取到每个位的数字,保存到列表中,对列表的下标进行全排列,获得全排列结果列表,遍历全排列的结果列表,逐个判断是否是2的幂,若有一个是2的幂,那么返回true,结束程序,若没有一个是2的幂,那么最后返回false,结束程序。

第一步

先判断一次原来的数字是否是2的幂,直接使用n >= 1 && (n & (n - 1)) == 0来判断,若这个条件成立,那么数字是2的幂,直接返回true,结束程序,否则继续程序。

为什么n >= 1 && (n & (n - 1)) == 0能判断出数字是否是2的幂?

请参考之前的文章:LeetCode刷题-2的幂

打开文章后,找到"方法2",里面有提到如何推导出使用n >= 1 && (n & (n - 1)) == 0来判断一个数字是否是2的幂。

第二步
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值