大数的阶乘 C语言

该程序实现了一个大数阶乘计算功能。通过数组存储大数,从低位到高位依次计算,处理进位问题。主程序测试了1、5和150的阶乘结果。核心函数fun()实现大数乘法,fun1()循环计算阶乘,printArr()输出结果。程序使用固定大小数组(102400位)存储计算结果,适用于大数运算,能正确输出1!、5!和150!的值。

cpp 复制代码
#include<stdio.h>
#define M  102400

int arr[M]={1};
int len =1;


void fun(int n){  //arr X n
	int f=0;//是否有进位 
	for(int i=0;i<len;i++){
		int tmp=n*arr[i]+f;
		arr[i]=tmp%10;
		f=tmp/10;
	}
	while(f){
		arr[len]=f%10;
		len++;
		f/=10;
	}	
}

void fun1(int n){
	for(int i=1;i<=n;i++)
		fun(i);
}

void printArr(){
	for(int i=0;i<len;i++){
		printf("%d",arr[len-i-1]);
	}
}

void test(int n){
	for(int i=0;i<M;i++){
		arr[i]=0;
	}
	arr[0]=1;
	fun1(n);
	printArr();
	puts("");
}

int main(){
	test(1);
	test(5);
	test(150);

	return 0;	
}
相关推荐
qq_423233901 分钟前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder12312 分钟前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_7155753414 分钟前
分布式任务调度系统
开发语言·c++·算法
Configure-Handler29 分钟前
buildroot System configuration
java·服务器·数据库
naruto_lnq35 分钟前
泛型编程与STL设计思想
开发语言·c++·算法
zxsz_com_cn1 小时前
设备预测性维护算法分类及优劣势分析,选型指南来了
算法·分类·数据挖掘
:Concerto1 小时前
JavaSE 注解
java·开发语言·sprint
m0_748708051 小时前
C++中的观察者模式实战
开发语言·c++·算法
然哥依旧1 小时前
【轴承故障诊断】基于融合鱼鹰和柯西变异的麻雀优化算法OCSSA-VMD-CNN-BILSTM轴承诊断研究【西储大学数据】(Matlab代码实现)
算法·支持向量机·matlab·cnn