鱼C论坛

 找回密码
 立即注册
查看: 3448|回复: 1

二进制加法问题的字符串“手工”模拟代码小白犯错

[复制链接]
发表于 2019-3-30 19:27:45 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Question:输入一个长度为32位的二进制数字,请你下一行打印其+1后的二进制加法结果。
例:
输入:
00000000000000000000000000000000
输出:
00000000000000000000000000000001
不知道利用字符串我的“递归”错在了哪里,应该是语法的问题,编程小白实在是太渣了
  1. #include <stdio.h>

  2. char a[32];                //32位的字符串
  3. int i;                     //处理字符串用的
  4. void plus(a[i])            //对字符串进行模拟加法运算
  5. {
  6.         if (a[i]=='0')         //该位置的字符为0,进行加1操作
  7.         {
  8.                 a[i] = '1';
  9.         }//if
  10.         else                   //该位置的字符为1,递归对下一“高位”进行加1操作
  11.         {
  12.                 plus(a[i-1]);
  13.         }//else
  14. }//plus

  15. int main()
  16. {
  17.         while (scanf_s("%s", a, 32) != EOF)
  18.         {
  19.                 i = 31;           //每次循环输入,将i置为31,从最“低”位开始模拟二进制加法操作
  20.                 plus(a[i]);
  21.                 printf("%s",a);   //输出结果
  22.         }//while
  23.         return 0;
  24. }//main
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-3-31 00:54:57 | 显示全部楼层
本帖最后由 jackz007 于 2019-3-31 00:57 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. char * dec2bin(char * bin , const int n , const int m)
  5. {
  6.         char c                                                                     ;
  7.         int d , k                                                                  ;        

  8.         if(n > 0) {
  9.                 c = n % 2                                                          ;
  10.                 if(c) c = '1'                                                      ;
  11.                 else c = '0'                                                       ;
  12.                 dec2bin(bin , n / 2 , m + 1)                                       ;
  13.                 for(k = 0 ; k < 32 && bin[k] ; k ++)                               ;
  14.                 bin[k ++] = c                                                      ;
  15.                 bin[k] = '\0'                                                      ;
  16.         } else {
  17.                 bin[0] = '\0'                                                      ;
  18.         }
  19.         if(! m) {
  20.                 d = strlen(bin)                                                    ;
  21.                 if(d < 32) {
  22.                         for(k = 0 ; k < d ; k ++) bin[32 - 1 - k] = bin[d - 1 - k] ;
  23.                         for(k = 0 ; k < 32 - d ; k ++) bin[k] = '0'                ;
  24.                         bin[32] = '\0'                                             ;
  25.                 }
  26.         }
  27.         return bin                                                                 ;
  28. }

  29. void plus(char b[])
  30. {
  31.         int k                          ;

  32.         k = 32                         ;
  33.         do {
  34.                 if(b[k - 1] == '1') {
  35.                         b[k - 1] = '0' ;
  36.                 } else {
  37.                         b[k - 1] = '1' ;
  38.                         break          ;
  39.                 }
  40.                 k --                   ;
  41.         } while(k > 0)                 ;
  42. }
复制代码


运行实况:
C:\Bin\Exercise\C>plus2
2147483647
2147483647
01111111111111111111111111111111
10000000000000000000000000000000

C:\Bin\Exercise\C>
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-5 14:09

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表