/*问题描述 输入一个正整数n,输出n!的值。 其中n!=1*2*3*…*n。 算法描述 n!可能很大,而计算机能表示的整数范围有限,需要使用高精度计算的方法。使用一个数组 A 来表示一个大整数a,A[0]表示 a 的个位,A[1]表示 a 的十位,依次类推。 将 a 乘以一个整数k 变为将数组 A 的每一个元素都乘以 k,请注意处理相应的进位。 首先将 a 设为 1,然后乘 2,乘 3,当乘到 n 时,即得到了 n!的值。 输入格式 输入包含一个正整数n,n<=1000。 输出格式 输出n!的准确值。 样例输入 10 样例输出 3628800 */ #include #include #define MAX 3000 int main() { int a[MAX],i,j,n; int c=0; //进位 int s; memset(a,0,sizeof(a)); scanf("%d",&n); a[0]=1; for(i=2;i<=n;i++) //乘数 { for(j=0;j=0;i--) //从第一个不为零的开始 if(a[i]) break; for(j=i;j>=0;j--) { printf("%d",a[j]); } return 0; } BASIC-29 高精度加法 /*问题描述 输入两个整数a 和b,输出这两个整数的和。a 和b 都不超过100 位。 算法描述 由于a 和b 都比较大,所以不能直接使用语言中的标准数据类型来存储。对于这种问题,一般使用数组来处理。 定义一个数组A,A[0]用于存储a 的个位,A[1]用于存储a 的十位,依此类推。同样可以用一个数组B 来存储b。 计算c = a + b 的时候,首先将A[0]与B[0]相加,如果有进位产生,则把进位(即和的十位数)存入r,把和的个位数存入C[0],即C[0]等于(A[0]+B[0])%10。然后计算A[1]与B[1]相加,这时还应将低位进上来的值r 也加起来,即C[1]应该是A[1]、B[1]和r 三个数的和.如果又有进位产生,则仍可将新的进位存入到 r 中,和的个位存到 C[1]中。依此类推,即可求出C 的所有位。 最后将C 输出即可。 输入格式 输入包括两行,第一行为一个非负整数a,第二行为一个非负整数b。两个整数都不超过100 位,两数的最高位都不是0。 输出格式 输出一行,表示 a + b 的值。 样例输入 20100122201001221234567890 2010012220100122 样例输出 20100122203011233454668012 */ #include #include #define MAXa 100 #define MAXb 100 #define MAXc 105 int main() { char a[MAXa],b[MAXb]; int i,j,c[MAXc],t,la,lb,n=...