C语言 - 计算n的阶乘(n!)

简介: C语言 - 计算n的阶乘(n!)

/***********************************************************************

目的:输入一个数计算它的阶乘

分析:

▶ 3! = 1 * 2 * 3

▶ 4! = 1 * 2 * 3 * 4

▶ 5! = 1 * 2 * 3 * 4 * 5

平台:Visual studio 2017 && windows

*************************************************************************/

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
  int i = 0;
  int ret = 1;
  int n = 0;
  scanf("%d", &n);
  for(i = 1; i <= n; i++)
  {
    ret *= i;
  }
  printf("%d\n", ret);
  return 0;
}

/***********************************************************************

目的:1! + 2! +3! + …

分析:

1    +

1 * 2    +

1 * 2 * 3 +

… …

平台:Visual studio 2017 && windows

*************************************************************************/

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
  int i = 0;
  int j = 0;
  int ret = 1;
  int sum = 0;
  int n = 0;
  scanf("%d", &n);
  for (i = 1; i <= n; i++)
  {
    ret = 1;//在求下一个阶乘时重新赋值,避免把上一阶乘的值与下一阶乘的值重复相乘
    for (j = 1; j <= i; j++)
    {
      ret *= j;
    }
    sum += ret;
  }
  printf("%d\n", sum);
  return 0;
}

/***********************************************************************

目的:优化:1! + 2! +3! + …

分析:上面这种写法时间复杂度高,效率低。优化如下:

1 * 1 = 1!

1! * 2 = 2!

2! * 3 = 3!

3! * 4 = 4!

… …

平台:Visual studio 2017 && windows

*************************************************************************/

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
int main()
{
  int i = 0;
  int ret = 1;
  int sum = 0;
  int n = 0;
  scanf("%d", &n);
  for(i = 1; i <= n; i++)
  {
    ret *= i;
    sum += ret;
  }
  printf("%d\n", sum);
  return 0; 
}



相关文章
|
21天前
|
存储 算法 安全
C 语言中的位运算:挖掘底层计算的高效力量
位运算是C语言中直接操作二进制位的一种技术,能高效处理底层数据,广泛应用于优化算法、硬件编程等领域,是掌握C语言高级特性的关键之一。
|
23天前
|
存储 算法 C语言
C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项
本文深入探讨了C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项,并通过案例分析展示了实际应用,旨在帮助读者提高编程效率和代码质量。
68 4
|
6月前
|
存储 C语言
【C语言刷题每日一题#牛客网HJ73】——计算日期到天数转换(给定日期,计算是该年的第几天)
【C语言刷题每日一题#牛客网HJ73】——计算日期到天数转换(给定日期,计算是该年的第几天)
|
6月前
|
存储 安全 C语言
【C语言刷题每日一题】——求最大公约数(带数学计算过程详解)
【C语言刷题每日一题】——求最大公约数(带数学计算过程详解)
|
6月前
|
存储 C语言
【C语言刷题每日一题】——计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果
【C语言刷题每日一题】——计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值,打印出结果
|
6月前
|
C语言
C语言---试计算在区间1 到n 的所有整数中,数字x(0 ≤ x ≤ 9)共出现了多少次?
C语言---试计算在区间1 到n 的所有整数中,数字x(0 ≤ x ≤ 9)共出现了多少次?
|
6月前
|
C语言
【C语言刷题系列】计算整数的二进制位中1的个数 (三种方式)
【C语言刷题系列】计算整数的二进制位中1的个数 (三种方式)
|
6月前
|
C语言
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
|
6月前
|
Serverless C语言
C语言----递归函数,计算一个非负整数的数字之和
C语言----递归函数,计算一个非负整数的数字之和
|
6月前
|
C语言
C语言---计算三角形的周长和面积--海伦公式
C语言---计算三角形的周长和面积--海伦公式