鱼C论坛

 找回密码
 立即注册
查看: 2025|回复: 13

[已解决]c语言递归

[复制链接]
发表于 2021-12-15 21:43:32 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
用递归算法计算n!


  1. #include "stdio.h"
  2. long fact(int n)
  3.    { long f;
  4.       if(n==1)  f=1;
  5.       else    f=n*fact(n-1);    /*此处的fact(n-1)有点不太懂*/
  6.       return  f;
  7. }
  8. void  main()
  9.    { long y;int n;
  10.       scanf("%d",&n);
  11.       y=fact(n);
  12.       printf("%d!=%d\n",n,y);
  13. }
复制代码

此处fact(n-1)怎么个递归法,逻辑有点乱,求助!!!!
最佳答案
2021-12-15 21:51:58
本帖最后由 jackz007 于 2021-12-15 21:58 编辑
  1. #include <stdio.h>
  2. unsigned long long fact(int n)
  3. {
  4.         return (n > 1) ? n * fact(n - 1) : 1LL ;
  5. }

  6. int main(void)
  7. {
  8.         unsigned long long y                   ;
  9.         int n                                  ;
  10.         scanf("%d" , & n)                      ;
  11.         printf("%d! = %I64u\n" , n , fact(n))  ;
  12. }
复制代码

        以计算 fact(5) 为例,分析递归过程
  1. fact(5) = 5 * fact(4)
  2.                    fact(4) = 4 * fact(3)
  3.                                       fact(3) = 3 * fact(2)
  4.                                                          fact(2) = 2 * fact(1)
  5.                                                                             fact(1) = 1
复制代码

fact(5) = 5 * fact(4) = 5 * 4 * fact(3) = 5 * 4 * 3 * fact(2) = 5 * 4 * 3 * 2 * fact(1) = 5 * 4 * 3 * 2 * 1
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-12-15 21:50:34 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-15 21:51:58 | 显示全部楼层    本楼为最佳答案   

回帖奖励 +5 鱼币

本帖最后由 jackz007 于 2021-12-15 21:58 编辑
  1. #include <stdio.h>
  2. unsigned long long fact(int n)
  3. {
  4.         return (n > 1) ? n * fact(n - 1) : 1LL ;
  5. }

  6. int main(void)
  7. {
  8.         unsigned long long y                   ;
  9.         int n                                  ;
  10.         scanf("%d" , & n)                      ;
  11.         printf("%d! = %I64u\n" , n , fact(n))  ;
  12. }
复制代码

        以计算 fact(5) 为例,分析递归过程
  1. fact(5) = 5 * fact(4)
  2.                    fact(4) = 4 * fact(3)
  3.                                       fact(3) = 3 * fact(2)
  4.                                                          fact(2) = 2 * fact(1)
  5.                                                                             fact(1) = 1
复制代码

fact(5) = 5 * fact(4) = 5 * 4 * fact(3) = 5 * 4 * 3 * fact(2) = 5 * 4 * 3 * 2 * fact(1) = 5 * 4 * 3 * 2 * 1
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-12-15 21:54:46 | 显示全部楼层

写的有点深奥,我初学啊,好多的没怎么看懂,我只看出来是简写的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2021-12-15 22:00:19 | 显示全部楼层
jackz007 发表于 2021-12-15 21:51
以计算 fact(5) 为例,分析递归过程

fact(5) = 5 * fact(4) = 5 * 4 * fact(3) = 5 * 4 * 3 * ...

后面这个一下子看懂了感谢感谢
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-12-15 23:10:59 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-16 08:04:15 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-16 08:18:32 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-16 08:34:26 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-16 09:43:45 | 显示全部楼层

回帖奖励 +5 鱼币

这个小甲鱼之前视频里讲过的,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2021-12-16 10:05:06 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-16 15:37:29 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-18 12:14:27 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2021-12-18 22:40:21 | 显示全部楼层

回帖奖励 +5 鱼币

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-24 14:43

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表