呃呃呃996 2021-12-02 22:05 采纳率: 100%
浏览 259
已结题

二进制数问题根据1和0的个数分为A B类

若将一个正整数化为二进制数,在此二进制数中,我们将数字1的个数多于数字0的个数的这类二进制数称为A类数,否则就称其为B类数。
例如:
(13)10=(1101)2

        其中1的个数为3,0的个数为1,则称此数为A类数;

(10)10=(1010)2

        其中1的个数为2,0的个数也为2,称此数为B类数;

(24)10=(11000)2
        其中1的个数为2,0的个数为3,则称此数为B类数;
程序要求:
求出1~1000之中(包括1与1000),全部A、B两类数的个数。
下面是我的代码,运行结果是1000 0
找不出哪错了,大佬们帮帮孩子吧😭

'代码'

           #include <stdio.h>
            int main()
            {
        int m = 0, i, p, q, a, n ;
        for (i = 1, p = 0, q = 0; i <= 1000; i++) {
    n = i;
    for (; n != 0;) {
        a = n % 2;
        n = n / 2;
        if (a == 0)
            q++;
        else
            p++;
    }
    if (p > q)
        m++;}
    printf("%d %d\n", m, 1000 - m);
return 0;
    }
  • 写回答

1条回答 默认 最新

  • 技术专家团-Bamboo 2021-12-02 22:08
    关注

    内层for循环对每一个i进行处理时,先要把p,q置0

    #include <stdio.h>
    
    int main() {
        int m = 0, i, p, q, a, n ;
        for (i = 1, p = 0, q = 0; i <= 1000; i++) {
            n = i;
            p = 0;
            q=0;
            for (; n != 0;) {
                a = n % 2;
                n = n / 2;
                if (a == 0)
                    q++;
                else
                    p++;
            }
            if (p > q)
                m++;
    
        }
        printf("%d %d\n", m, 1000 - m);
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 12月10日
  • 已采纳回答 12月2日
  • 修改了问题 12月2日
  • 创建了问题 12月2日

悬赏问题

  • ¥15 WPF 大屏看板表格背景图片设置
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示