免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2863 | 回复: 19
打印 上一主题 下一主题

大家是怎么实现的 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-10-30 21:53 |只看该作者 |倒序浏览
只用一句程序判断一个整数是否2的幂  不准用循环

论坛徽章:
0
2 [报告]
发表于 2007-10-30 21:58 |只看该作者
不准用循环可以用递归吗?

论坛徽章:
0
3 [报告]
发表于 2007-10-30 22:07 |只看该作者
来个最简单的:

n == 0 || n == 1 || n == 2 || n == 4 ... || n == 0x40000000

论坛徽章:
0
4 [报告]
发表于 2007-10-30 22:08 |只看该作者
递归是可以滴:wink:

论坛徽章:
0
5 [报告]
发表于 2007-10-30 22:08 |只看该作者
2的幂就是说:为0或者只有一位是1
x&(x-1)就应该等于0

如果有两个或者两个以上的1那么x&(x-1)肯定不等于0

所以判断x&(x-1)即可

论坛徽章:
0
6 [报告]
发表于 2007-10-30 22:12 |只看该作者
原帖由 sanbiangongzi 于 2007-10-30 22:08 发表
2的幂就是说:为0或者只有一位是1
x&(x-1)就应该等于0

如果有两个或者两个以上的1那么x&(x-1)肯定不等于0

所以判断x&(x-1)即可


:wink: :wink: :wink:

论坛徽章:
0
7 [报告]
发表于 2007-10-30 22:13 |只看该作者
原帖由 sanbiangongzi 于 2007-10-30 22:08 发表
2的幂就是说:为0或者只有一位是1
x&(x-1)就应该等于0

如果有两个或者两个以上的1那么x&(x-1)肯定不等于0

所以判断x&(x-1)即可



晕了,更正,0不是2的幂哈

所以应该是 (x && (x&(x-1)))

论坛徽章:
0
8 [报告]
发表于 2007-10-30 22:19 |只看该作者
试一下这样。。。

if x == 0
     条件处理
else
    判断log10(x)/log10(2)是否为整数。。

论坛徽章:
0
9 [报告]
发表于 2007-10-30 22:20 |只看该作者
正解  .........

论坛徽章:
0
10 [报告]
发表于 2007-10-30 22:23 |只看该作者
可以封帖了  两种方法都有了
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP