栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

初始c语言函数递归

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

初始c语言函数递归

1.什么是递归

程序调用自身的编程技巧叫做递归.。一个过程或函数在其定义或说明中直接或间接调用自身的一种方法

2.递归的两个必要条件

1.存在条件限制,当满足这个限制条件时候,递归就不再继续

2.每次递归调用之后越来越接近这个限制条件

递归错误1.

int main()
{
    printf("hello world");
    main();
    return 0;
}

没有终止条件,会造成死循环 栈溢出

什么是栈溢出?

栈区 (局部变量 函数形参) 堆区(动态内存分配的 malloc/free calloc realloc)

静态区(全局变量 静态变量)

在每一次递归时都会重新在内存中创建新的空间 然后超过了最大的空间 导致栈溢出

3.写递归时的注意事项

1.不能死递归 都有跳出条件 每次递归逼近跳出条件

2.递归层次不能太深

练习1:

编写函数不允许创建临时变量 求字符串长度

int my_strlen(char* str)
{
    if (*str != ''){
        return 1 + my_strlen(str + 1);
    }else{
        return 0;
    }
}
int main()
{
    char arr[] = "bit";
    // 模拟实现strlen函数
    printf("%dn", my_strlen(arr));
}

2.求n的阶乘

int Factorial(int x)
{
    if (x<=1){
        return 1;
    }else{
        return x * Factorial(x - 1);
    }
}
int main()
{
    int n = 0;
    scanf("%d", &n);
    int sum = Factorial(n);
    printf("%dn", sum);
    return 0;
}

3.斐波那契数列

int add(int a)
{
    if (a <= 2){
        return 1;
    }else{
        return add(a - 1) + add(a - 2);
    }
}
int main()
{
    int a = 6;
    int sum = add(a);
    printf("%dn", sum);
    return 0;
}

 优化版:

int add(int n)
{
    int a = 1;
    int b = 1;
    int c = 1;
    while (n>2){
        c = a + b;
        a = b;
        b = c;
        n--;
    }
    return c;
}
int main()
{
    int a = 10;
    int sum = add(a);
    printf("%d", sum);
    return 0;
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/833102.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号