捏妈第三节的题单名不是循环结构吗,直接出了第八节的高精度大数计算,紧急学习

对于较大数的加减乘除阶乘等,C/C++原生的数据类型是存储不了的(即便用longlong),直接计算会出现数据移除成负数的结果

为了解决这类超大数的运算,我们选择用字符数组或者整型数组来进行模拟运算。

所谓模拟运算也就是把大数的每一位存储到数组的一个数组元素中,然后模拟类似于列竖式手算的形式来一位一位的进行运算

最后输出的时候当然也是一位一位的输出了,而且为了计算进位方便,通常倒序存储数字,同时输出时倒序输出

P1009d

这道题其实就是让我们用高精度阶乘加上高精度加法来算结果

 1 #include<stdio.h>
5 int main()
6 {
7 int N;
8 scanf("%d", &N);//阶乘指标输入
9 int Factorial[1000] = { 0 };//Factorial,阶乘的英语,嘿嘿

//这个数组用来存储每次阶乘的结果
10     Factorial[0] = 1;//初始化
11 int Num = 0;//进位指示,初始无进位数据
12 int Digit = 1;//当前数组或者说大数的位数,同时也可以作为逆序输出的指针 14 for (int i = 1; i <= N; i++)
15 {
16 for (int j = 0; j <Digit; j++)
17 {
18 int Temp = Factorial[j] * i + Num;//临时数据存储,包含计算数据以及上次保存的进位数据
19 Factorial[j] = Temp % 10;
20 Num = Temp / 10;//将个位存入当前位的数组,十位的数字存入进位指示进入下一轮
21 }
22 while(Num)//进位数据若未取完,说明要顺延进位
23 {
24 Factorial[Digit] = Num%10;
25 Num = Num / 10;//对于百位及以上未取完进位数据的处理,因为乘法进位可能会超过十位,这一点加法就不用考虑了
26 Digit++;//进位,位数加一
27 }
28 }
29 for (int i = Digit - 1; i >= 0; i--)//以Digit为倒序指针来倒序输出
30 {
31 printf("%d", Factorial[i]);
32 }
33 return 0;
34 }

上面是独立的大数阶乘实现,由于是从已知数一步一步累乘,所以比大数乘法实现更简洁简单

下面是阶乘整合大数的加法

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int* Factor(int N,int* Digit)
{
int* Factorial = (int*)malloc(sizeof(int) * 1000);//堆上申请便于返回!!!,刚开始我是申请在栈上的数组,出错了wwww
memset(Factorial, 0, sizeof(Factorial));//赋值0
Factorial[0] = 1;//初始化
int Num = 0;//进位指示,初始无进位数据
//这个数组用来存储每次阶乘的结果
for (int i = 1; i <= N; i++)
{
for (int j = 0; j < *Digit; j++)
{
int Temp = Factorial[j] * i + Num;//临时数据存储,包含计算数据以及上次保存的进位数据
Factorial[j] = Temp % 10;
Num = Temp / 10;//将个位存入当前位的数组,十位的数字存入进位指示进入下一轮
}
while (Num)//进位数据若未取完,说明要顺延进位
{
Factorial[*Digit] = Num % 10;
Num = Num / 10;//对于百位及以上未取完进位数据的处理
(* Digit)++;//进位,位数加一
}
} return Factorial; }
int main()
{
int N;
scanf("%d", &N);//阶乘指标输入
int Sum[1000] = { 0 };
for (int i = 1; i <= N; i++)
{
int Digit = 1;
int* F = Factor(i,&Digit);
int Num = 0;//与上述阶乘实现一样, Num依旧为进位指标
for (int k = 0; k < Digit;k++)
{
int Temp = F[k] + Sum[k]+Num;//两数相加再加上上一轮继承来的进位数
Sum[k] = Temp % 10;//取个位
Num = Temp / 10;//取十位
}
if (Num)
{
Sum[Digit] += Num;
Num = 0;//在仅考虑十位进制的情况下可以更简单的处理
}
free(F); F = NULL;//内存回收
}
int k = 999;
for (; !Sum[k]; k--);//过滤掉前导的0
for (; k >= 0; k--)
{
printf("%d", Sum[k]);
}
return 0;
}

洛谷P1009 阶乘之和的更多相关文章

  1. 洛谷——P1009 阶乘之和

    P1009 阶乘之和 题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一 ...

  2. 洛谷P1009 阶乘之和 题解

    想看原题请点击这里:传送门 看一下原题: 题目描述 用高精度计算出S=!+!+!+…+n! (n≤) 其中“!”表示阶乘,例如:!=****××××. 输入格式 一个正整数N. 输出格式 一个正整数S ...

  3. Java实现 洛谷 P1009 阶乘之和

    import java.util.Scanner; public class 阶乘之和 { public static void main(String[] args) { Scanner sc = ...

  4. 洛谷 P1009 阶乘之和 Label:高精度

    题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一个正整数S,表示计算结 ...

  5. 洛谷 P1009 阶乘之和

    题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一个正整数S,表示计算结 ...

  6. P1009 阶乘之和

    P1009 阶乘之和 题目提供者洛谷OnlineJudge 标签数论(数学相关)高精1998NOIp提高组NOIp普及组 难度普及- 通过/提交1139/3791 提交该题 讨论 题解 记录 题目描述 ...

  7. AC日记——阶乘之和 洛谷 P1009(高精度)

    题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=5*4*3*2*1. 输入输出格式 输入格式: 一个正整数N. 输出格式: 一个正整数S,表示计算结 ...

  8. P1009 阶乘之和 洛谷

    https://www.luogu.org/problem/show?pid=1009 题目描述 用高精度计算出S=1!+2!+3!+…+n!(n≤50) 其中“!”表示阶乘,例如:5!=54321. ...

  9. 【洛谷】P1009阶乘之和

    题目链接:https://www.luogu.org/problemnew/show/P1009 题意:给一个整数n(n<50),求$ \sum^{n}_{i=1} i! $ 题解:我..拿py ...

  10. 【洛谷】P1009 阶乘之和——高精度算法

    题目描述 用高精度计算出S = 1! + 2! + 3! + - + n!  ( n ≤  50 ) S = 1! + 2! + 3! + - + n! ( n ≤ 50 ) 其中"!&qu ...

随机推荐

  1. 6 Englishi 词根

    9 pend/pends = hang 悬挂 depend   de 向下 independent   in 前缀 表否定: ent  adj后缀 suspend    sus=sub(便于发音) p ...

  2. 《3D编程模式》写书-第5次记录

    大家好,这段时间我完成了对初稿的第一轮修改,即将开始第二轮的修改 这里是所有的的写书记录: <3D编程模式>写书记录 本轮修改主要进行了下面的修改: 修改错误 修改了UML错误.文字错误. ...

  3. HOMER docker版本配置优化

    概述 HOMER是一款100%开源的针对SIP/VOIP/RTC的抓包工具和监控工具. HOMER是一款强大的.运营商级.可扩展的数据包和事件捕获系统,是基于HEP/EEP协议的VoIP/RTC监控应 ...

  4. 每天学五分钟 Liunx 101 | 存储篇:LVM

    LVM LVM(Logical Volume Manager),逻辑卷管理器.一种高级文件系统管理方式,它可以动态扩展文件系统.   LVM 的示意图如下所示:

  5. python · matplotlib | 如何绘制子图

    代码: import matplotlib.pyplot as plt import matplotlib matplotlib.rc("font",family='MicroSo ...

  6. WPF Prism框架Region失效了?

    站长最近转载了痕迹的Prism 8系列博文,不知道你对该框架是否有一定了解了?不了解,可以看看本号转载的系列: WPF Prism框架合集(2.创建Prism应用程序) WPF Prism框架合集(3 ...

  7. AspNetCore在docker里访问Oracle数据库的坑:ORA-01882: timezone region not found

    哦吼 之前刚说了尝试了使用docker来部署AspNetCore应用,结果这才刚上班就遇到问题了= =- 我这项目用的数据库是Oracle,之前直接运行没啥问题,但放在docker里运行就报了这个错误 ...

  8. Chrony 的学习与使用

    Chrony 的学习与使用 背景 之前捯饬 ntp 发现很麻烦, 经常容易弄错了. 昨天处理文件精确时间时 想到了时间同步. 发现只有自己总结的ntpdate 但是还没有 chronyd相关的总结 本 ...

  9. [转帖]pyinstaller实现将python程序打包成exe文件

    https://www.cnblogs.com/blogzyq/p/13939739.html 如果我们想要在一个没有python以及很多库环境的电脑上使用我们的小程序该怎么办呢? 我们想到,在Win ...

  10. Windows 挂载minio 到本地磁盘

    Windows 挂载minio 到本地磁盘 背景 新公司建议使用minio 进行一些业务操作 已经在各位领导同事的帮助下找到了linux本地s3fs挂载和k8s使用csi方式挂载到pod内的方式. 今 ...