#include<stdio.h>
int main()
{
int a,b,n,i=2,j=3;
scanf("%d %d %d",&a,&b,&n);
long long s[n+1];
s[1]=a,s[2]=b;
for(;;j++,i++)
{
s[j]=s[i]*s[i-1];
//i控制相乘的数字,而j控制得出的数字
//j无论如何相乘出的结果都会是两位数字,因为i控制的数字都是个位数
if(s[j]>=10)
{
long long num=s[j],t=0,a[1000],c;
for(c=num;num>0;c=num,t++)
{
a[t]=c%10;
num/=10;
}
//先将j的个位和十位存在a中
c=t-1;
for(;c>=0;c--,j++)
s[j]=a[c];
//将a中的值全部赋给s
j--;
}
if(j>=n) break;
}
//此过程中,j一直在向前走,负责储存结果,i一直在缓慢前进,以i控制相乘的两个数字
printf("%lld",s[1]);
for(i=2;i<=n;i++) printf(" %lld",s[i]);
}
L1-080乘法口诀数列
最新推荐文章于 2022-05-12 11:00:00 发布