免费注册 查看新帖 |

Chinaunix

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

[算法] [算法问题]判断一个数是不是2的正整数次幂? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-07-10 23:30 |只看该作者 |倒序浏览
位操作的运用:

  1. bool Is2Power(int nNum)
  2. {
  3.         return nNum > 0 ? ((nNum & (~nNum + 1)) == nNum ? true : false) : false;
  4. }
复制代码

[ 本帖最后由 converse 于 2006-7-11 00:18 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-07-10 23:44 |只看该作者
见过n次了

论坛徽章:
0
3 [报告]
发表于 2006-07-10 23:52 |只看该作者
原帖由 Orpherus 于 2006-7-10 23:44 发表
见过n次了


嗯,好的。知道了。

论坛徽章:
0
4 [报告]
发表于 2006-07-10 23:59 |只看该作者
原帖由 Orpherus 于 2006-7-10 23:44 发表
见过n次了


温故知新,留个念想~~

论坛徽章:
0
5 [报告]
发表于 2006-07-11 00:00 |只看该作者
1/4=2^(-2)
利用楼主的方法不能解,嘿嘿,有点挑骨头了。

论坛徽章:
0
6 [报告]
发表于 2006-07-11 00:09 |只看该作者
原帖由 liubinbj 于 2006-7-11 00:00 发表
1/4=2^(-2)
利用楼主的方法不能解,嘿嘿,有点挑骨头了。


1/4?你指的是-2次幂么?哦...我没有写清楚,应该是判断是不是2的正整数次幂.

论坛徽章:
0
7 [报告]
发表于 2006-07-11 00:42 |只看该作者
原帖由 快乐的土豆 于 2006-7-11 00:33 发表
看到过一个版本


和楼主的有啥区别?


应该是

  1. int Is2Power(int nNum)
  2. {
  3.         return !(nNum & (nNum - 1));
  4. }
复制代码

论坛徽章:
0
8 [报告]
发表于 2006-07-11 00:46 |只看该作者
to 土豆,你给的那个算法当输入是0的时候返回true...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP