当前位置: 首页 > news >正文

C语言:递归

递归简单来说就是函数自己调用自己。

特点:一般代码比较简洁,没有出口。

例子1:用一个函数计算阶乘

#include<stdio.h>//不用递归
int fac(int n)
{int val = 1;for (int i = 1; i <=n;i++){val *= i;}return val;
}//用递归
int fac1(int n)
{if (n == 1){return 1;}return n * fac1(n - 1);
}int main()
{printf("%d\n", fac(5));printf("%d\n", fac1(5));return 0;
}

例子2:斐波那契值

#include<stdio.h>//1 2 3 4 5 6 7  8   从第三个数开始,它的值等于它前两项的和
//1 1 2 3 5 8 13 21
//用递归
int fibonacci(int n)
{if (n == 1 || 2 == n){return 1;}return fibonacci(n - 2) + fibonacci(n - 1);
}//循环法
int fibo(int n)
{if (1 == n || 2 == n){return 1;}int v1 = 1;int v2 = 1;int v3;for (int i=3;i<=n;i++){v3 = v1 + v2;v1 = v2;v2 = v3;}return v3;
}int main()
{printf("%d\n", fibo(40));printf("%d\n", fibonacci(40));return 0;
}

例子3:倒序打印

#include<stdio.h>void print(char* str)//abcd dcba倒序打印
{if (*str == '\0'){return;}print(str + 1);        //printf("%c", *str);此为正打印printf("%c", *str);    //print(str + 1);    abcd abcd
}int main()
{print("abcd");return 0;
}


http://www.mrgr.cn/news/3315.html

相关文章:

  • PHP概述、环境搭建与基本语法讲解
  • 【网络】套接字(socket)编程——TCP版
  • 【MADRL】基于MADRL的单调价值函数分解(QMIX)算法
  • FPGA时序约束
  • 【数据分享】《中国社会统计年鉴》(2006-2023)
  • JavaScript_7_练习:随机抽奖案例
  • 代码随想录算法训练营第二十九天| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
  • 【企业高性能web服务器】
  • 数据结构day03(栈 Stack 顺序栈、链式栈 )内含具体详细代码实现
  • 场景分析-库存扣减
  • 宠物空气净化器是智商税吗?希喂、范罗士热门产品真实性能测试
  • 8个我平时每天都会看的网站,涵盖办公、娱乐、学习等
  • 使用Python将xml标注文件转换为coco json格式
  • Leetcode-day23-回溯-子集问题
  • 白酒与素食:健康与美味的双重享受
  • 转化轮询数据成树状结构
  • 什么是数据仓库ODS层?为什么需要ODS层?
  • SAP Parallel Accounting(平行分类账业务)配置及操作手册【适用于多国家会计准则】
  • Python 设置Excel工作表页边距、纸张大小/方向、打印区域、缩放比例
  • 鸿蒙HarmonyOS开发知识:命令行工具篇—“codelinter”