计算n个阶乘之和

简介: 方法一:错误情况截图:正确情况截图:方法二:运行代码:运行结果截图:

@TOC

方法一:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(vodi)
{
    //2.计算1!+2!+……n!n个阶乘之和
    int i = 0, j=0,n = 0;
    int ret = 1,sum=0;
    scanf("%d", &n);
    for (i = 1; i <=n; i++)
    {
        ret = 1;//语句A
        for (j = 1; j <= i;j++)
        ret = j * ret;
        sum += ret;
    }
    printf("%d", sum);
    return 0;
}

经典错误:语句A忘记写上,导致ret仍保留上一次运算的结果,产生累加效果!!!

错误情况截图:

在这里插入图片描述

正确情况截图:

在这里插入图片描述

方法二:

方法一时间复杂度较高为O(N^2),故改进:

运行代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
int main(vodi)
{
    //2.计算1!+2!+……n!n个阶乘之和 方法二:
    int i = 0, n = 0;
    int ret = 1, sum = 0;
    scanf("%d", &n);
    for (i = 1; i <=n; i++)
    {
        ret = ret * i;
        sum += ret;
    }
    printf("%d", sum);
    return 0;
}

运行结果截图:

在这里插入图片描述

目录
相关文章
|
2月前
计算自然数的和
【10月更文挑战第18天】计算自然数的和。
42 10
|
2月前
通过最大公约数计算
【10月更文挑战第20天】通过最大公约数计算。
39 5
|
2月前
|
机器学习/深度学习
阶乘
【10月更文挑战第20天】阶乘。
24 4
|
7月前
|
算法 C++
C++求阶乘的深入探索
C++求阶乘的深入探索
235 0
|
7月前
|
存储 程序员 C语言
利用循环结构实现数字的阶乘计算
利用循环结构实现数字的阶乘计算
85 0
|
7月前
|
C语言
求阶乘之和
【1月更文挑战第18天】C语言实例——求阶乘之和。
44 3
|
机器学习/深度学习
1173:阶乘和
1173:阶乘和
|
算法 Python
计算阶乘之和
计算阶乘之和
111 0
L1-013 计算阶乘和 (10 分)
L1-013 计算阶乘和 (10 分)
63 0