课后练习代码
#include <iostream>
#include <string.h>
#define SIZE 7
using namespace std;
int* multipliers(int* num1,int size1,int* num2,int size2)
{
int* ret=new int[size1+size2];
memset(ret,0,sizeof(int)*(size1+size2));
for(int i=0;i<size2;++i)//先不进位乘出结果
{
int k=i;
for(int j=0;j<size1;++j)
{
ret[k++]+=num1[j]*num2[i];
}
}
for(int i=0;i<size1+size2;++i)//这里进行进位处理
{
if(ret[i>9])
{
ret[i+1]+=ret[i]/10;
ret[i]%=10;
}
}
return ret;
}
int main()
{
int num1[]={1,1,1,1,1,1,6};//6111111(将数字倒放入数组中)
int num2[]={1,1,1,1,1,1,5};//5111111
int* ret=multipliers(num1,SIZE,num2,SIZE);//SIZE是数组的长度
for(int i=(SIZE)*2-1;i>=0;--i)
{
cout << ret[i];
}
return 0;
}
仅供参考