柠(♡˙︶˙♡)檬 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日

悬赏问题

  • ¥20 数学建模数学建模需要
  • ¥15 c语言数据结构实验单链表的删除
  • ¥15 关于#lua#的问题,请各位专家解答!
  • ¥15 什么设备可以研究OFDM的60GHz毫米波信道模型
  • ¥15 不知道是该怎么引用多个函数片段
  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决