C语言练习之求n的阶乘

简介: C语言练习之求n的阶乘

前言

运用最近学习的C语言知识,使用递归和非递归两种方法分别实现求n的阶乘(不考虑溢出的问题)

一、原理及思路

原理:

求n的阶乘

n! = n*(n-1)*(n-2)*(n-3)······2*1

特殊的,当n = 0时,n! = 1。

思路:

由原理我们可以得到一个公式:

以5!为例,它的递推过程如下

f(5) -->5*f(4)

              f(4)-->4*f(3)

                           f(3)-->3*f(2)

                                         f(2)-->2*f(1)

                                                       f(1)=1

将f(1)的值回代到上一步,以此回推,最终就能得到原式的结果。

二、源代码以及运行截图

为了方便大家的交流和学习,我将程序源代码和运行截图放置在下方。

非递归:

源代码:

#include<stdio.h>
int main()
{
  int n = 1;
  int m = 1;
  int input = 0;
  printf("请输入要计算阶乘的数:>");
  scanf("%d", &input);
  if (input < 0)
  {
    printf("输入错误!\n");
  }
  else if (input != 0)
  {
    for (n = 1; n <= input; n++)
    {
      m *= n;
    }
  }
  printf("这个数的阶乘为%d\n", m);
  return 0;
}

运行截图:

递归:

源代码:

#include<stdio.h>
int Fct(int input)
{
  if (input < 0)
  {
    printf("输入错误!\n");
    return -1;
  }
  else if (input == 0)
  {
    return 1;
  }
  else
  {
    return input*Fct(input - 1);
  }
}
int main()
{
  int input = 0;
  printf("请输入要计算阶乘的数:>");
  scanf("%d", &input);
  printf("这个数的阶乘为%d\n", Fct(input));
  return 0;
}

运行截图:

 


总结

以上就是今天要讲的内容,本文简单的介绍了用C语言中的循环和递归两种思路实现n的阶乘的求解,还进一步展示了代码的运行结果验证了作者的思路。

本文的作者也只是一个正在学习C语言等编程知识的萌新,若这篇文章中有哪些不正确的内容,请在评论区向作者指出(也可以私信作者),欢迎大佬们指点,也欢迎其他正在学习C语言的萌新和作者进行交流。

最后,如果本篇文章对你有所启发的话,也希望可以支持支持作者,后续作者也会定期更新学习记录。谢谢大家!

相关文章
|
8月前
|
C语言
|
8月前
|
C语言
C语言练习代码第一篇
C语言练习代码第一篇
|
8月前
|
编译器 C语言
|
8月前
|
C语言
|
8月前
|
C语言
C语言---循环迭代---n的阶乘
C语言---循环迭代---n的阶乘
|
8月前
|
C语言
C语言---递归--求n的阶乘
C语言---递归--求n的阶乘
|
8月前
|
存储 C语言
C语言实现阶乘
C语言实现阶乘
162 0
|
9月前
|
存储 前端开发 算法
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣(下)
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣
33 0
|
9月前
|
存储 C语言
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣(中)
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣
49 0
|
9月前
|
算法 C语言 容器
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣(上)
从C语言到C++_18(stack和queue的常用函数+相关练习)力扣
60 0

热门文章

最新文章