求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!的程序。
写一个数组相加的函数。