题目:
首先要清楚阶乘定义,所谓 n 的阶乘,就是从 1 开始乘以比前一个数大 1 的数,一直乘到 n,用公式表示就是:1×2×3×4×…×(n-2)×(n-1)×n=n!
具体的操作: 利用循环解决问题,设循环变量为 i,初值为 1,i 从 1 变化到 n;依次让 i 与 sum 相乘,并将乘积赋给 sum。
1. 定义变量 sum,并赋初值 1;
2. i 自加 1;
3. 直到 i >n 循环结束。
#include <stdio.h>
int main()
{
int i,n;
double sum=1; //sum定义为双精度浮点型
scanf("%d",&n);//高版本编译器中使用scanf_s
for(i=1;i<=n;i++)
{
sum=sum*i; //for循环体--sum乘以i的值赋值给sum
}
printf("%d!=%lf",n,sum); //输出结果为浮点型数据,默认保留6位小数
printf("n");
return 0;
}
思路:while表达式中判定循环停止的标准是i<=n,循环体只需要添加i自增就可。
#include <stdio.h>
#include <math.h>
int main()
{
int n,i=1,j=1;
scanf("%d",&n);
if(n>1&&n<=10) //此次代码增加限制条件,现在最高运算整数10的阶乘
{
while(i<=n)
{
j=j*i;
i++;
}
printf("%dn",j);
}
return 0;
}
方法三:主函数外 使用函数递归方法实现—-函数调用自身的思想 代码的利用率更高
1. 函数Func(Type a,……)直接或间接调用函数本身,则该函数称为递归函数;
#include <stdio.h>
int Fact(int n) //递归函数
{
int res=n;
if(n>1)
res=res*Fact(n-1);
return res;
}
int main() //主函数
{
int n,cnt;
scanf("%d",&n);
cnt=Fact(n);
printf("%dn",cnt);
return 0;
}
#include<stdio.h>
int fun(int n)
{
if(n==1||n==0) return 1;//如果参数是0或者1返回1
return n*fun(n-1);//否则返回n和下次递归的积
}
int main()
{
int n;
scanf("%d",&n);
printf("%dn",fun(n));
return 0;
}
代码运行结果为:
方法四:主函数外写一个子函数 在主函数内使用直接进行调用该子函数的方法实现
更加直接美观、可读性强
代码示例如下:
#include<stdio.h>
void factorial()
{
int number;
int factorial = 1;
scanf_s("%d", &number);
for(int i=1; i<=number; i++)
{
factorial = i*factorial;//确保即便当number=0的时候,结果也为1
}
printf("%d ", factorial);
}
int main()
{
factorial();//<==>直接把主要代码这部分给另拿出来,然后在主函数中进行调用
}
运行结果如下:
代码示例如下:
#include<stdio.h>
int main()
{
int n, m = 1, pro;
long fact(int);//实现阶乘的函数
printf("Input n:");
scanf_s("%d", &n);
for (; m <= n; m++)
pro = fact(m);
printf("%d!=%ldn", n, pro);
}
long fact(int n)
{
static long pro = 1;//pro即product---乘积
pro = pro * n;
return(pro);
}
代码运行结果如下:
编著注:以上对本小题的代码编写的多种方法,欢迎大家收藏借鉴并转发;
版权所有,翻印必究,如有雷同纯属巧合,转载请注明出处。
By CRH380AJ2808 2022.04.20
————————————————
版权声明:本文为CSDN博主「CRH380AJ2808」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:
原文地址:https://blog.csdn.net/JH13thpig/article/details/124294723
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_41894.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!