| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 883 人关注过本帖, 1 人收藏
标题:1的个数?
只看楼主 加入收藏
天谈2011
Rank: 1
等 级:新手上路
帖 子:24
专家分:0
注 册:2011-3-27
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:13 
1的个数?
一个数的二进制表示中有多少个1,写一个程序来完成?
搜索更多相关主题的帖子: 二进制 
2011-04-18 22:54
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:10 
程序代码:
#include <stdio.h>
int main (void) {
        int a=15,n=0;
        do {
                if(a%2==1) n++;
                a/=2;
        }while(a!=0);
        printf ("%i\n",n);
        return 0;
}

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-04-18 23:01
默默学习
Rank: 4
等 级:业余侠客
帖 子:134
专家分:200
注 册:2010-6-22
收藏
得分:5 
楼上正解。
2011-04-18 23:05
zaixuexi
Rank: 12Rank: 12Rank: 12
来 自:上海
等 级:火箭侠
威 望:8
帖 子:858
专家分:3233
注 册:2010-12-1
收藏
得分:5 
unsigned char BitsCount(unsigned char ch)
{
    ch = (ch & 0x55) + ((ch >> 1) & 0x55);
    ch = (ch & 0x33) + ((ch >> 2) & 0x33);
    ch = (ch & 0x0f) + ((ch >> 4) & 0x0f);
    return ch;
}

技术问题,请不要以短消息方式提问
2011-04-18 23:06
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
以下是引用zaixuexi在2011-4-18 23:06:35的发言:

unsigned char BitsCount(unsigned char ch)
{
    ch = (ch & 0x55) + ((ch >> 1) & 0x55);
    ch = (ch & 0x33) + ((ch >> 2) & 0x33);
    ch = (ch & 0x0f) + ((ch >> 4) & 0x0f);
    return ch;
}

LS高见, 下月计划开始学习 Operations On Bits , 目前还不大懂这些!

[ 本帖最后由 ansic 于 2011-4-18 23:16 编辑 ]

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-04-18 23:12
zaixuexi
Rank: 12Rank: 12Rank: 12
来 自:上海
等 级:火箭侠
威 望:8
帖 子:858
专家分:3233
注 册:2010-12-1
收藏
得分:0 
回复 5楼 ansic
一些比较小的问题,从不懂到懂也就没几天时间

技术问题,请不要以短消息方式提问
2011-04-18 23:14
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:0 
以下是引用zaixuexi在2011-4-18 23:14:39的发言:

一些比较小的问题,从不懂到懂也就没几天时间

嗯, 对于聪明人当然如此, 对于我这样愚钝之人, 还是需要些时日的。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-04-18 23:26
vfdff
Rank: 6Rank: 6
等 级:侠之大者
威 望:8
帖 子:2172
专家分:425
注 册:2005-7-15
收藏
得分:0 
回复 4楼 zaixuexi
unsigned char BitsCount(unsigned char ch)
{
    ch = (ch & 0x55) + ((ch >> 1) & 0x55);
    ch = (ch & 0x33) + ((ch >> 2) & 0x33);
    ch = (ch & 0x0f) + ((ch >> 4) & 0x0f);
    return ch;
}
这个算法什么意思?

~~~~~~~~~~~~~~~好好学习~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
2011-04-19 00:07
岳三路
Rank: 2
等 级:论坛游民
帖 子:23
专家分:19
注 册:2011-3-30
收藏
得分:0 
路过。。。。。。
重在学习。。
2011-04-19 00:17
zaixuexi
Rank: 12Rank: 12Rank: 12
来 自:上海
等 级:火箭侠
威 望:8
帖 子:858
专家分:3233
注 册:2010-12-1
收藏
得分:0 
回复 8楼 vfdff
假设只有2个位
00  00>>1 + 00 = 00 + 00 = 00b = 0d
01  01>>1 + 01 = 00 + 01 = 01b = 1d
10  10>>1 + 00 = 01 + 00 = 01b = 1d
11  11>>1 + 01 = 01 + 01 = 10b = 2d
其他情况以此类推

技术问题,请不要以短消息方式提问
2011-04-19 09:32
快速回复:1的个数?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016556 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved