C++求阶乘 C++求阶乘的两种方法

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

C++求阶乘 C++求阶乘的两种方法

  2021-03-19 我要评论
想了解C++求阶乘的两种方法的相关内容吗,在本文为您仔细讲解C++求阶乘的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:C++,求阶乘,下面大家一起来学习吧。

1.使用静态局部变量static
静态局部变量在函数调用结束之后不消失而保留原值,即其占用的存储单元不释放,在下一次该函数调用时,该变量保留上一次函数调用结束时的值。

静态局部变量赋初值实在编译时进行的,即只赋初值一次,在程序运行时它已有初值。

code:

复制代码 代码如下:

#include<iostream>
using namespace std;
int fac(int n)
{
 static int f=1;
 f=f*n;
 return f;
}
int main()
{
 int i;
 for(i=1;i<=5;i++)
 {
  cout<<i<<"!="<<fac(i)<<endl;
 }
 return 0;
}

print:

复制代码 代码如下:

/*
1!=1
2!=2
3!=6
4!=24
5!=120
*/

2.使用递归的方法
首先进行退出递归的判断,然后进行递归

code:

复制代码 代码如下:

#include<iostream>
using namespace std;
int fac(int n)
{
 if(n<0) return 0;
 if(n==0||n==1)return 1;
 if(n>1)
 {
  return n*fac(n-1);
 }
}
int main()
{
 int i;
 for(i=1;i<=5;i++)
 {
  cout<<i<<"!="<<fac(i)<<endl;
 }
 return 0;
}

print:

复制代码 代码如下:

/*
1!=1
2!=2
3!=6
4!=24
5!=120
*/

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们