云枭女 发表于 2021-1-9 11:28:16

C语言

可不可以帮忙解释一下这个程序的步骤吖{:5_105:}
//数制转换,输入一个8位二进制数,将其转换为十进制数输出。例如,输入11101101,则输出237
#include <stdio.h>
int power(int,int);
int main(){
        inti,value=0;
        charch;
        printf("Input an 8 bits binary number:");       
        for (i=7;i>-1;i--){
          ch=getchar();
          if (ch=='\n'){
             printf("Not enough 8 bits.\n");
             return -1;
      }
          if (ch=='1')
                value += power(2,i);
        }
        printf("Decimal value is:%d\n",value);
    return 0;
}
int power(int base, int n){
        int val =1;
        while (n--)
           val *= base;
        return (val);
}

心驰神往 发表于 2021-1-9 11:39:58

本帖最后由 心驰神往 于 2021-1-9 11:56 编辑

只是看步骤的话,下个断点,然后调试就行了。如果清楚二进制转十进制的话就很好明白
#include <stdio.h>
int power(int,int);//被调用函数power放在了主函数后面,在主函数之前一定要事先对被调用函数加以声明。
int main(){
      inti,value=0;
      charch;
      printf("Input an 8 bits binary number:");      
      for (i=7;i>-1;i--){
            ch=getchar();
            if (ch=='\n'){
               printf("Not enough 8 bits.\n");
               return -1;
      }
            if (ch=='1')
                value += power(2,i);//调用power函数,假如输入的是11101101,那么就是2^7+2^6+2^5+2^3+2^2+2^0
      }
      printf("Decimal value is:%d\n",value);
    return 0;
}

//函数求base的n次方val,返回值为val
int power(int base, int n){
      int val =1;
      while (n--)
         val *= base;//当n大于0时执行循环
      return (val);
}

云枭女 发表于 2021-1-9 15:57:05

心驰神往 发表于 2021-1-9 11:39
只是看步骤的话,下个断点,然后调试就行了。如果清楚二进制转十进制的话就很好明白

感谢吖,其实我知道这个函数的结构,我只是有点不明白它内在的逻辑,就是
for (i=7;i>-1;i--){
            ch=getchar();
            if (ch=='\n'){
               printf("Not enough 8 bits.\n");
               return -1;
      }
            if (ch=='1')
                value += power(2,i);//调用power函数,假如输入的是11101101,那么就是2^7+2^6+2^5+2^3+2^2+2^0
      }是如何实现输入二进制数的。
int power(int base, int n){
      int val =1;
      while (n--)
         val *= base;//当n大于0时执行循环
      return (val);
}
又是如何实现转变为十进制数的

心驰神往 发表于 2021-1-9 16:00:52

云枭女 发表于 2021-1-9 15:57
感谢吖,其实我知道这个函数的结构,我只是有点不明白它内在的逻辑,就是
for (i=7;i>-1;i--){
      ...

题目要求是输入八位二进制数,for (i=7;i>-1;i--)这句i在这个程序中代表的是第几位,就拿11101101来说
i=7代表的是11101101

心驰神往 发表于 2021-1-9 16:09:09

本帖最后由 心驰神往 于 2021-1-9 16:25 编辑

心驰神往 发表于 2021-1-9 16:00
题目要求是输入八位二进制数,for (i=7;i>-1;i--)这句i在这个程序中代表的是第几位,就拿11101101来说
...

这样说也不太对,我想想怎么说
for (i=7;i>-1;i--)如果在i=7到i=0之间输入换行符时
if (ch=='\n'){
               printf("Not enough 8 bits.\n");
               return -1;
      }就会判断出来:位数不足八位发生错误getchar()返回-1,
用户输入的字符被存放在键盘缓冲区中,当键入回车之后,getchar才开始从输入流中每次读入一个字符,输入的字符不只一个的时候,后续的getchar直接读取缓冲区中的字符
所以如果正好输入八位那么会按照这个假如输入的是11101101,那么就是2^7+2^6+2^5+2^3+2^2+2^0
但是输入大于八位比如假如输入的是011101101,那么就是2^6+2^5+2^4+2^2+2^1=118
具体getchar用法你可以看这个https://blog.csdn.net/qq_28238141/article/details/79927332
不知道这样合适不


云枭女 发表于 2021-1-11 18:23:27

心驰神往 发表于 2021-1-9 16:09
这样说也不太对,我想想怎么说
for (i=7;i>-1;i--)如果在i=7到i=0之间输入换行符时
if (ch=='\n'){ ...

嗯,好欸,感谢你呀

心驰神往 发表于 2021-1-11 19:33:09

云枭女 发表于 2021-1-11 18:23
嗯,好欸,感谢你呀

没事
页: [1]
查看完整版本: C语言