柠(♡˙︶˙♡)檬 2022-04-17 16:56 采纳率: 100%
浏览 31
已结题

十进制转换为二进制的问题

十进制转换为二进制,不明白为什么i=n-1而不是i=n

#include <stdio.h>
#include<stdlib.h>
int main()
{
    int num;
    int n = 0;
    int arr[100];
    scanf("%d", &num);
    while (num != 0)
    {
        arr[n++] = num % 2;
        num = num / 2;
    }
    
    for (int i =n-1; i>=0; --i)
    {
        printf("%d", arr[i]);
    }
    system("pause");
    return 0;
}

  • 写回答

1条回答 默认 最新

  • a5156520 2022-04-17 17:21
    关注

    因为当数组arr存储整数num最后一个二进制位上的值后还++了一次,所以n的值是比实际最后一个二进制位存储的下标还要大1,
    所以打印二进制位时,是从n-1这个下标开始。你可以这样测试一下,先把数组a每个元素的值从0到99赋值,然后获取输入(如9)转换后,
    从n开始打印会发现第一个值实际存储最大二进制位的后一位的值,也可以打印n的值为多少来判断,测试代码如下:

    
    #include <stdio.h>
    #include<stdlib.h>
    int main()
    {
        int num;
        int n = 0;
        int arr[100];
        scanf("%d", &num);
        int j;
        for(j=0;j<100;j++){
            arr[j]=j+1;
        }
        
        while (num != 0)
        {
            arr[n++] = num % 2;
            num = num / 2;
        }
        printf("n=%d\n",n);
        for (int i =n; i>=0; --i)
        {
            printf("%d", arr[i]);
        }
        system("pause");
        return 0;
    }
     
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 系统已结题 5月13日
  • 已采纳回答 5月5日
  • 创建了问题 4月17日

悬赏问题

  • ¥15 pyqt5 中python如何通过Qtwebchannel主动发消息给web前端
  • ¥15 关于HTML中title获取xml内容的问题
  • ¥15 fanuc机器人PRIO083数字信号未复原错误,如何解决?
  • ¥20 如何为现有电路板增加远程控制功能
  • ¥15 C#点击按钮的时候的循环次数就是最后一次,如何是循环第几次的值?
  • ¥15 UE5打包失败,求解决
  • ¥15 请问STM32G431的CANOPEN协议函数怎么写
  • ¥15 graphpad prism 三因素重复测定报错
  • ¥15 openbmc ast2500如何修改MCR04寄存器使用ddr4
  • ¥15 关于#LTC#的问题,如何解决?(相关搜索:示波器)