递归,算法可能出错

时间:2013-05-09 12:09:19

标签: c algorithm recursion

我正在做一个简单的程序C,5位数字的数字之和。尽管我已经使用一个简单的函数完成了它,但我还需要用递归来做。我在网上读过很多关于这个问题的解决方案使用递归并实现了我的一个。但这是错误的,我无法弄清楚我在算法中做了什么网格。

#include<stdio.h>
int sum5(int x);  //function for sum of  digits of 5 digit number

int main()
{
   int x;
   int result;
   printf("Enter a 5 digit number : ");
   scanf("%d",&x);
   printf("Number entered by you is %d",x);
   result = sum5(x);
   printf("Sum of digits of 5 digit number is = %d",&result);
   return 0;
}

int sum5(int x)
{
   int r;
   int sum=0;
   if(x!=0){
      r=x%10;
      sum=sum+r;
      x=x-r;      //doing this so that 0 come in the last and on diving it by 10, one digit will be removed.
      sum5(x/10);
   }
   return sum;
}

但在执行后我得到了错误的结果。它正在输出一些匿名值。

2 个答案:

答案 0 :(得分:8)

这是不正确的,因为它正在打印result地址而不是其值:

printf("Sum of digits of 5 digit number is = %d",&result);

更改为:

printf("Sum of digits of 5 digit number is = %d", result);

始终检查scanf()的结果以确保读取有效值:

/* Returns number of assignments made. */
if (scanf("%d", &x) == 1 && x > 9999 && x < 100000)
{
}

加上Osiris 所指出的sum5()实施中的错误。

答案 1 :(得分:8)

此外,您的sum5功能不正确。您必须将sum5的值添加到调用方函数的sum变量中。

int sum5(int x)
    {
        int r;
        int sum = 0;
        if (x != 0) {
            r = x % 10;
            sum = r;
            //x = x - r;  - this isn't required. integer division will floor x
            sum += sum5(x / 10);
        }
        return sum;
    }