| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 12479 人关注过本帖
标题:求各位看一下这个为什么老报错
只看楼主 加入收藏
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
收藏
得分:0 
回复 19楼 藤田惠美
下次我会尽量多写注释。
2016-10-11 22:10
哈斯佛道
Rank: 2
等 级:论坛游民
帖 子:23
专家分:81
注 册:2016-8-15
收藏
得分:1 
#include<stdio.h>
void main()
{
    unsigned int i,n,p,m,q=0;
    printf("请输入一个正整数\n");
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
        p=i;
        do
        {   
            m=p&1;
            if(m!=0)q++;
            p=p>>1;
        }
        while(p!=0);
    }
    printf("1~n用二进制表示时1的个数为:%d\n",q);
}
按之前那位大神的算法编了下,感觉这样思路更清晰

[此贴子已经被作者于2016-10-11 22:39编辑过]

2016-10-11 22:36
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
收藏
得分:0 
能解释一下m=p&1是什么意思吗?
2016-10-11 23:40
word123
Rank: 10Rank: 10Rank: 10
等 级:贵宾
威 望:13
帖 子:333
专家分:1622
注 册:2014-4-5
收藏
得分:0 
1   0000000000000001
p   0000000000000101

m=p&1   &是按位与
只看最后一位,因为1除最后一位都是0,结果肯定是0
若p最后一位是1,&之后结果是1,不等于0,相当于检测到一个1
p>>1   p向右移动一位  0000000000000010
继续上次操作,直到p为0,现在p中不会再有1了
2016-10-12 00:04
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
收藏
得分:0 
好的
2016-10-12 10:41
快速回复:求各位看一下这个为什么老报错
数据加载中...
 
   



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

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