一、问题描述
写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和,
例如,调用DigitSum(1729),则应该返回1 + 7 + 2 + 9,它的和是19。
二、问题分析
要求一个数字的每位数之和,首先得求出每一位的数字,然后再去相加。这里最主要的问题就是如何求出每一位,这个问题也称为剥离数位(在数位遍历上也会用到)。
num%10得到的是个位数字,num/10得到的是略去个位之后的数字,因此这样反复,就可以求出每位数字。
三、代码实现
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int DigitSum(int n);
int main() {
//写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和,
//例如,调用DigitSum(1729),则应该返回1 + 7 + 2 + 9,它的和是19
int n;
printf(“请输入一个非负整数”);
scanf("%d", &n);
int result=DigitSum(n);
printf("%d ",result);
system(“pause”);
return 0;
}
int DigitSum(int n) {
if (n < 10)
{
return n;
}
else {
return n % 10 + DigitSum(n / 10);
}
}
四、运行结果

C语言编程小练习-求各位数字之和
最新推荐文章于 2025-09-23 22:58:38 发布
本文详细解析了一个使用递归算法求解非负整数中各位数字之和的C语言实现。通过逐步剥离数字的每一位并求和,展示了递归函数DigitSum的定义与使用。代码实例清晰地说明了递归调用的过程,帮助读者理解递归机制。
965

被折叠的 条评论
为什么被折叠?



