找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2318|回复: 0
打印 上一主题 下一主题
收起左侧

C语言算法:你的代码是否高效?

[复制链接]
跳转到指定楼层
楼主
ID:60266 发表于 2014-8-19 18:04 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
1、写一个高效C语言程序,计算一个无符号整数中1的个数
0000----------0
0100----------1
1001----------2
1111----------4
一般思路肯定是循环右移判断与0x0001相与的结果是否为1。
算法如下:
unsigned char count; unsigned int x;
for ( count=0; x; count++)
x&=x-1;
最后循环的次数count 就是无符号int型数据中1的个数。
若求比特0的个数,则程序修改如下(16位单片机):
unsigned char count; unsigned int x;
for ( count=16; x; count--)
x&=x-1;


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表