二进制数之和(使用 C 样式字符串)

Sum Of Binary Numbers (using C Style Strings)

我正在开发一个程序,通过命令行输入(argv、argc)将两个二进制数相加。它也是左对齐的。

例如:$a.out 0 1 returns 1, $a.out 10 1 returns 11 等等

我正在使用一个函数来做加法,我 100% 知道我的问题出在我的函数中,但我不知道我做错了什么。当我添加两个进位为“0”的二进制数时,它不会在总和中打印“1”。我还有另一个问题,有些金额是反向打印的,但其他的不是。如果有人能指出我做错事的正确方向,我将不胜感激。

错误的和示例:

$a.out 10 10
00      // should be "100"
$a.out 11 11
01      // should be "110"
$a.out 100 100
000     // should be "1000"
$a.out 110000 1
100011 // should be "110001"

我的函数:

bool add (const char aug[], const char add[], char sum[])
//aug is the first command line binary number (argv[1]), add is the second (argv[2])
{

    char carry = '0';
    int ag = strlen(augend) - 1;
    int ad = strlen(addend) - 1;
    int max = ((ag > ad)? ag : ad);

    for (int i = 0; i <= max; ag--, ad--, i++)
    {
         char augDigit = (ag < 0)? '0' : augend[ag];
         char addDigit = (ad < 0)? '0' : addend[ad];

         switch (augDigit + addDigit + carry)
         {
             case '0' + '0' + '0':
                 sum[i] = '0';
                 carry = '0';
                 break;
             case '1' + '0' + '0':
                 sum[i] = '1';
                 carry = '0';
                 break;
             case '1' + '1' + '0':
                 sum[i] = '0';
                 carry = '1';
                 break;
             case '1' + '1' + '1':
                 sum[i] = '1';
                 carry = '1';
                 break;
          }
    }    
    return true; 
    // returns true if the sum is less than 36 digits but I'll deal with         
    // that once i fix this issue
}

两个原因:第一个原因是您以相反的顺序存储结果,第二个原因是您没有考虑最后一个进位。如果最后一个和执行了,你必须在结果中附加另一个 '1'