题目描述
用高精度计算出 S = 1! + 2! + 3! + \cdots + n!S=1!+2!+3!+⋯+n!(n \le 50n≤50)。
其中 !
表示阶乘,定义为 n!=n\times (n-1)\times (n-2)\times \cdots \times 1n!=n×(n−1)×(n−2)×⋯×1。例如,5! = 5 \times 4 \times 3 \times 2 \times 1=1205!=5×4×3×2×1=120。
输入格式
一个正整数 nn。
输出格式
一个正整数 SS,表示计算结果。
输入输出样例
输入 #1复制
3
输出 #1复制
9
说明/提示
【数据范围】
对于 100 \%100% 的数据,1 \le n \le 501≤n≤50。
【其他说明】
注,《深入浅出基础篇》中使用本题作为例题,但是其数据范围只有 n \le 20n≤20,使用书中的代码无法通过本题。
如果希望通过本题,请继续学习第八章高精度的知识。
NOIP1998 普及组 第二题
#include <iostream>
int a[100],b[100]; // 定义两个数组a和b,用于存储高精度的加法和乘法结果
using namespace std;
// 高精度加法函数
void add()
{
int c=0; // 定义一个变量c,用于存储进位
for(int i=0;i<100;++i) // 遍历数组a和b的元素
{
c+=a[i]+b[i]; // 将a[i]和b[i]相加,并加上进位c
a[i]=c%10; // 更新a[i]为相加后的个位数
c/=10; // 更新进位c为相加后的十位数
}
}
// 高精度乘法函数
void mul(int x)
{
int c=0; // 定义一个变量c,用于存储进位
for(int i=0;i<100;i++) // 遍历数组b的元素
{
c+=b[i]*x; // 将b[i]乘以x,并加上进位c
b[i]=c%10; // 更新b[i]为相乘后的个位数
c/=10; // 更新进位c为相乘后的十位数
}
}
int main() {
int n;
cin >> n; // 输入一个整数n
b[0]=1; // 初始化数组b的第一个元素为1
for(int i=1;i<=n;i++) // 从1到n进行循环
{
mul(i); // 调用高精度乘法函数,将数组b的每个元素乘以i
add(); // 调用高精度加法函数,将数组a和b的对应元素相加
}
int k=100; // 定义一个变量k,用于记录数组a中第一个非零元素的下标
for(;k>=0;k-- ) // 从数组a的最后一个元素开始向前遍历
if(a[k]>0) break; // 如果找到第一个非零元素,跳出循环
for(int i=k;i>=0;i--) // 从第一个非零元素开始向前遍历数组a
cout<<a[i]; // 输出数组a的元素
return 0;
}