houqing1999 发表于 2023-5-26 20:23:51

s1e34递归动动手

#include <stdio.h>

void binary(unsigned long n);

void binary(unsigned long n)
{
      int r;

      r = n % 2;
      if (n >= 2)
      {
                binary(n / 2);
      }

      putchar('0' + r); // '0' + 1 == '1'这里还是不太清楚,什么0+1==1这是二进制里面的?
}

int main(void)
{
      unsigned long number;

      printf("请输入一个正整数:");
      scanf("%lu", &number);

      binary(number);
      putchar('\n');

      return 0;
}

sfqxx 发表于 2023-5-26 20:38:25

占楼

isdkz 发表于 2023-5-26 21:01:39

你提供的代码是一个简单的C语言程序,用于将十进制数转换为二进制数。它从用户那里接收一个无符号的长整型数,然后打印出该数字的二进制表示。

关于你的问题 '0' + 1 == '1' ,这与字符在内存中如何表示有关。在C(以及许多其他语言)中,字符是通过ASCII值来表示的。字符 '0' 的ASCII值是48,字符 '1' 的ASCII值是49。所以,当你做 '0' + 1 时,相当于说"给我一个字符,它的ASCII值比字符'0'的ASCII值大1",这就是 '1' 。

简单来说, '0' 和 '1' 在这里不是数字,它们是字符。表达式 '0' + 1 是将字符 '0' 的ASCII值增加1,得到字符 '1' 的ASCII值。

这是一种巧妙的方式,用于将整数0或1转换为字符'0'或'1'。这是必要的,因为 putchar() 函数期望的是一个字符,而不是一个整数。

以下是代码中的工作方式:
·r = n % 2; 获取 n 除以2的余数。由于除以2,这个余数只可能是0或1,因为这是除以2可能的唯一余数。
·putchar('0' + r); 然后将这个0或1转换为字符'0'或'1'并打印出来。如果 r 是0,那么 '0' + r 是 '0' ,如果 r 是1,那么 '0' + r 是 '1' 。

柿子饼同学 发表于 2023-5-26 21:15:17

每个字符都有对应的 ASCII 码值 , 字符 '0' 的 ASCII 码是 48 , '1' 的码是 49 , 所以 , '0' + 1 相当于给 '0' 的 ASCII 码值加一 , 也就是 49 , 所以当 r 为 1 时就会输出 1
当 r 为 0 时 , 输出 '0' (48 + 0 == 48 == '0')

sfqxx 发表于 2023-5-26 21:25:05

来晚了,555

houqing1999 发表于 2023-5-27 22:44:04

sfqxx 发表于 2023-5-26 21:25
来晚了,555

男子汉哭有什么用,下次罚五公里{:10_340:}

sfqxx 发表于 2023-5-27 22:44:48

houqing1999 发表于 2023-5-27 22:44
男子汉哭有什么用,下次罚五公里

{:10_312:}

sfqxx 发表于 2023-5-27 22:45:35

houqing1999 发表于 2023-5-27 22:44
男子汉哭有什么用,下次罚五公里

给这个帖子评点点分吧{:10_254:}

https://fishc.com.cn/thread-228545-1-1.html

求5荣誉,3贡献{:10_254:}

谢谢啦

houqing1999 发表于 2023-5-27 23:19:35

sfqxx 发表于 2023-5-27 22:45
给这个帖子评点点分吧

https://fishc.com.cn/thread-228545-1-1.html


{:10_323:}

sfqxx 发表于 2023-5-28 12:29:57

houqing1999 发表于 2023-5-27 23:19


谢谢
页: [1]
查看完整版本: s1e34递归动动手