使用程序写出求出1!+2!+...+64!的运算结果。考虑溢出的问题

求10的阶乘的和
int n=10;
int num1=1;
int num2=1;
for(int i=1;i<=n;i++)
{
    num1=1;
    for(int j=2;j<=i;j++)
	{
	    num1*=j;
	}
	sum+=num1;
}
/*写一个数组,数组每一位存一位数,就可以保存一个很大的数
当要处理很大的数的乘法的时候,超出了数据的保存范围,可以使用一个长的数组来保存每一位,用下面的来实现运算结果。
    3   7    2
            18
1计算每一位的结果			
	54  126 36
2进位和留位
    54  126 36   	
             6
         3
    12
    66  9   6
*/

int length=20	
int *arr=new int[length];

arr[length-1]=2;
arr[length-2]=7;
arr[length-3]=3;
int num=16;

for(int i=0;i<length;i++)
{
   arr[i]*=num;//计算每一位
}
//进和留
for(int i=length-1;i>0;i--)
{
    arr[i-1]+=arr[i]/10;
	arr[i]=arr[i]%10;
}
for(int i=0;i<length;i++)
{
   cout<<arr[i]<<" ";
}
编程求64!的值


#include <iostream>
#include "stdio.h"
#include "string.h"
#include <stdlib.h>
using namespace std;

void demo(int *arr,int num,int length);
int main()
{

//利用数组进行多位数的乘法运算
   */
   int n=64;
   int result[100]={0};
    result[99]=1;
   for(int i=1;i<=n;i++)
   {
       demo(result,i,100);
   }
   for(int i=0;i<100;i++)
   {
       cout<<result[i];
   }

    system("Pause");
    return 0;
}


   void demo(int *arr,int num,int length)
{
    for(int i=0;i<length;i++)
    {
       arr[i]*=num;//计算每一位
    }
    //进和留
    for(int i=length-1;i>0;i--)
    {
        arr[i-1]+=arr[i]/10;
        arr[i]=arr[i]%10;
    }

}

运算结果:

后面有兴趣可以写一个1!+2!+3!+.....+64!的程序。

写一个数组相加的函数。

猜你喜欢

转载自blog.csdn.net/usstmiracle/article/details/84831421