|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
『 C语言论坛 』
→ 请问关于《C程序设计语言》40面左下角的BITCOUNT函数 ,怎么也不理解啊
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
959
人关注过本帖
标题:
请问关于《C程序设计语言》40面左下角的BITCOUNT函数 ,怎么也不理解啊
只看楼主
加入收藏
jkf2012
等 级:
论坛游民
帖 子:18
专家分:30
注 册:2010-11-18
结帖率:
100%
楼主
收藏
已结贴
√
问题点数:15 回复次数:2
请问关于《C程序设计语言》40面左下角的BITCOUNT函数 ,怎么也不理解啊
/* bitcount函数:统计X中值为1的二进制位数 */
int bitcount(unsigned x)
{
int b;
for (b = 0; x != 0 ; x >>= 1)
if (x & 01)
b++;
return b;
}
这个函数小弟从头到尾都看不懂啊,实在是想不明白,哪位朋友能给小弟讲解讲解啊,描述一下算法,实在是想不通~
搜索更多相关主题的帖子:
程序设计
BITCOUNT
函数
语言
左下角
2010-11-27 22:40
举报帖子
使用道具
赠送鲜花
xiaoyukeai
等 级:
新手上路
帖 子:1
专家分:5
注 册:2010-11-4
第
2
楼
收藏
得分:5
~~我也是菜鸟,说说我的见解,希望没有误导你~:如果X不等于0,则右移一位,由于右移计算,且操作数不为负数,所以,是前面会补上0。然而再把这个值跟1进行位与操作,与操作,就是,只要有一个是0,值就是0。如果与操作不为0,也就是说,X的二进制形式,还是有1的位数,计数器加1~~楼主如果明白数的二进制就应该懂了~~
2010-11-28 00:18
举报帖子
使用道具
赠送鲜花
xiaomarn
等 级:
小飞侠
威 望:
5
帖 子:348
专家分:2026
注 册:2009-3-18
第
3
楼
收藏
得分:10
int bitcount(unsigned x)
{
int b;
for (b = 0; x != 0 ; x >>= 1)
if (x & 01)
b++;
return b;
}
如一个二进制数x=01001110b
在这个循环中首先检查x是否为零,不是就与00000001b相与,即(100111
0
&00000001)得到最后一位即00000000b
if判断0为假,b不加1
执行x >>= 1移位操作,x=01001110>>1=
0
010011
1
,检查x是否为零,继续前面操作
2010-11-28 16:19
举报帖子
使用道具
赠送鲜花
3
1/1页
1
快速回复:
请问关于《C程序设计语言》40面左下角的BITCOUNT函数 ,怎么也不理解啊 ...
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.022400 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved