(C语言)写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和(递归函数)

cpp 复制代码
#include <stdio.h>
int DigitSum(int n){
    if(n<10){
        return n;
    }
    return (n%10)+DigitSum(n/10);
}
int main(){
    printf("请输入一个非负整数:\n");
    int a=0;
    while(1){
        if(scanf("%d",&a)!=1 || a<0){
            printf("输入不合法请重新输入非负整数!!\n");
        }else{
            break;
        }
    }
    int x=DigitSum(a);
    printf("组成%d的数字之和是%d",a,x);
    return 0;
}

今天的代码非常的简单啊~

首先while函数判断输入是否合法,不合法就重新输入

然后定义递归函数思路:

要想实现这个功能,就要拆分这个非负整数,也就是各个位数分开,比如123,分成1 2 3,然后再相加即可

因此,我们用n/10,来剔除个位,以此调用递归,返回时,再用n%10(也就是求个位数),最后让他们加起来就行了

递归过程是这样的:

cpp 复制代码
DigitSum(123) → 3 + DigitSum(12)  
DigitSum(12)  → 2 + DigitSum(1)  
DigitSum(1)   → 1  
最终结果:3 + 2 + 1 = 6  

如果你对递归过程不了解,可以看我的这期博客:

(C语言)递归函数教学(C语言教学)-CSDN博客

运行结果如下:

cpp 复制代码
请输入一个非负整数:
123
组成123的数字之和是6
请按任意键继续. . .

注:该代码是本人自己所写,可能不够好,不够简便,欢迎大家指出我的不足之处。如果遇见看不懂的地方,可以在评论区打出来,进行讨论,或者联系我。上述内容全是我自己理解的,如果你有别的想法,或者认为我的理解不对,欢迎指出!!!如果可以,可以点一个免费的赞支持一下吗?谢谢各位彦祖亦菲!!!!!

相关推荐
小馒头学python11 分钟前
蓝耘智算|从静态到动态:探索Maas平台海螺AI图片生成视频功能的强大能力
人工智能·python·学习·算法·aigc
百锦再12 分钟前
《C#上位机开发从门外到门内》3-3:基于USB的设备管理系统
开发语言·单片机·数码相机·c#·上位机·下位机
Channing Lewis12 分钟前
Python print() 打印多个变量时,可变对象和不可变对象的区别
开发语言·python
小辉同志1 小时前
C语言之链表
c语言·开发语言·链表
Q_Boom3 小时前
LeetCode 环形链表II:为什么双指针第二次会在环的入口相遇?
算法·leetcode·链表
SsummerC3 小时前
【leetcode100】括号生成
python·算法·leetcode
gotoc丶3 小时前
堆排序:力扣215.数组中的第K个大元素
javascript·数据结构·算法·leetcode·排序算法
一只_程序媛3 小时前
【leetcode hot 100 199】二叉树的右视图
算法·leetcode·职场和发展
一只_程序媛3 小时前
【leetcode hot 100 230】二叉搜索树中第K小的元素
算法·leetcode·职场和发展
Tiger Z4 小时前
R 语言科研绘图 --- 密度图-汇总
开发语言·程序人生·r语言·贴图