【头歌】递归与嵌套

1. 用递归求Sn=1!+2!+3!+4!+5!+…+n!之值,其中n是一个数字:

#include<stdio.h>
long long solve(long long n){
    /*********Begin*********/
    long long sum = 1;
    while (n){
        sum = sum * n;
        n--;
    }
    return sum;
    /*********End**********/
}
int main(void)
{
    long long n;
    scanf("%lld",&n);
    long long ans=0;
    for(long long i=1;i<=n;i++)
        ans+=solve(i);
    printf("%lld", ans);
    return 0;
}

2.编写一个递归函数,将一个整数n逆序输出,比如,n = 12345,输出54321:

#include<stdio.h>
void solve(int n){
    printf("%d", n%10);
    /*********Begin*********/
    n /= 10;
    /*********End**********/
    if(n>0) solve(n);
}
int main(void)
{
    int n;
    scanf("%d",&n);
    solve(n);
    return 0;
}

3.用递归法将一个整数n转换成字符串。例如,输入n为483,输出字符串 4 8 3,每个数字后面接一个空格用于隔开字符:

#include<stdio.h>
void solve(int n){
    int temp=n%10;
    /*********Begin*********/
    n /= 10;
    if(n) solve(n);
    /*********End**********/
    if(n)
        printf(" %d", temp);
    else
        printf("%d", temp);
}
int main(void)
{
    int n;
    scanf("%d",&n);
    solve(n);
    return 0;
}

4.编写一函数实现下列Ackman函数,其中m,n为正整数 样例输入: 1 1 样例输出: 3

#include<stdio.h>
int Acm(int m,int n){
    if(m==0&&n>0)
        /*********Begin*********/
        return n+1;
        /*********End**********/
    else if(n==0&&m>0)
        /*********Begin*********/
        return Acm(m-1,1);
        /*********End**********/
    else
        /*********Begin*********/
        return Acm(m-1,Acm(m,n-1));
        /*********End**********/
}
int main(void)
{
    int m,n;
    scanf("%d%d",&m,&n);
    printf("%d", Acm(m,n));
    return 0;
}
  • 6
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
函数嵌套指在一个函数中调用另一个函数,而递归则是指函数调用自身的过程。 在C语言中,函数嵌套可以让程序更加模块化,便于维护和阅读,也可以提高程序的可重用性。例如,一个函数中需要调用另一个函数来完成某个功能,可以将这个函数嵌套在主函数中。 函数嵌套的语法很简单,例如: ```c void func1() { printf("This is function 1\n"); } void func2() { printf("This is function 2\n"); func1(); } int main() { func2(); return 0; } ``` 在上面的例子中,func2()函数中调用了func1()函数。 递归则是指一个函数调用自身的过程。递归函数必须包含一个停止条件,否则将会出现无限递归导致程序崩溃。递归函数可以用于解决一些问题,例如计算阶乘、斐波那契数列等。 下面是一个计算阶乘的递归函数的示例: ```c int factorial(int n) { if (n == 0) { return 1; } else { return n * factorial(n - 1); } } int main() { int result = factorial(5); printf("%d", result); return 0; } ``` 在上面的例子中,factorial()函数调用自身来计算阶乘。当n等于0时,递归停止,函数返回1。否则,函数计算n的阶乘并返回结果。 需要注意的是,递归函数的效率有时候并不高,因为每次调用函数都需要将函数的参数和返回地址等信息压入栈中,消耗了一定的时间和内存。因此,在使用递归函数时,应该尽量避免出现无限递归的情况,以及递归次数过多导致栈溢出等问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值