トピック:
ここのタイトルは 1 ~ 20 の階乗の合計の例です
方法 1: for ループのレイヤーを使用して、コードがシンプル、高速、理解しやすいことを実現します。
コード例は次のとおりです。
#include<stdio.h>
int main()
{
double a = 1, sum = 0;//因为最后值可能会超出int所能接收的范围 故用double
int n, i;
scanf("%d", &n);//注意scanf_s和scanf的使用场景
for (i = 1; i <= n; i++)
{
a = a*i;
sum = sum + a;
}
printf("%lld", sum);//double的输入格式要对
return 0;
}
操作の結果は次のようになります。
方法 2: for ループのネストを 2 層使用する
コード例は次のとおりです。
//需要注意对于1-20阶乘结果已经超出了int能够接收的范围
// 故用double类型
//1.遍历获取每一个数字[1-20]
//2.对每一个数进行阶乘
//3.对每个数字的阶乘结果进行求和
int main()
{
double total_sum = 0.0;
for (int i = 1; i <= 20; i++)//i控制求和
{
//i=8 ---> 8*7*6*....*1
double single_num = 1.0;
for (int j = i; j > 0; j--)
{
single_num *= j;//j控制阶乘
}
total_sum += single_num;
}
printf("%lf\n", total_sum);
return 0;
}
操作の結果は次のようになります。
方法 3: 関数の再帰的実装
#include<stdio.h>
long int fac(unsigned int n) //定义为long int 型,避免溢出
{
long int f;
if (n == 0) return; //当n=0是,递归法到尽头,依次返回函数值。
f = fac(n - 1) * n;
return (f); //返回最后一次函数值,即单次阶乘的最后结果
}
int main()
{
unsigned int n;
long int s =0;
int i;
scanf_s("%d", &n);//此处注意scanf_s与scanf的使用场景
for (i = 1; i <= n; i++) s += fac(i); //以循环控制阶乘的和。fac函数每一次的返回值作为s的自加值
printf("%ld", s);
return 0;
}
#include<iostream>
#include<cmath>
double fac(double t)
{
if (t == 1)
return 1;
else
return t * fac(t - 1);
}
int main()
{
using namespace std;
double i, n, sum = 0;
cin >> n;
if (n > 14)
return 0;
for (i = 1; i < n; i++)
{
double b = fac(i);
sum += b;
}
cout << "sum =" << sum << endl;
printf("%lf\n", sum);
return 0;
}
コードを実行した結果は次のようになります。
編集者注: このトピックのコードを記述する上記のさまざまな方法を収集し、学び、広めることを歓迎します。
上記のコードは参照のみを目的としています。質問がある場合は、メッセージ領域で批判および修正してください。
著作権はすべて留保されており、再版は調査する必要があります。類似点はまったくの偶然です。再版のソースを示してください。
By CRH380AJ2808 2022.04.26
———————————————
著作権に関する声明: この記事は CSDN ブロガー「CRH380AJ2808」のオリジナル記事であり、CC 4.0 BY-SA 著作権契約に従って、転載する場合は元のソース リンクとこの声明を添付してください。
元のリンク: https://blog.csdn.net/JH13thpig/article/details/124361837