乘法口诀数列

7-62 乘法口诀数列 (20 分)

本题要求你从任意给定的两个 1 位数字 a​1​​ 和 a​2​​ 开始,用乘法口诀生成一个数列 {a​n​​},规则为从 a​1​​ 开始顺次进行,每次将当前数字与后面一个数字相乘,将结果贴在数列末尾。如果结果不是 1 位数,则其每一位都应成为数列的一项。
输入格式:

输入在一行中给出 3 个整数,依次为 a​1​​、a​2​​ 和 n,满足 0≤a​1​​,a​2​​≤9,0<n≤10​3​​。
输出格式:

在一行中输出数列的前 n 项。数字间以 1 个空格分隔,行首尾不得有多余空格。
输入样例:

2 3 10

输出样例:

2 3 6 1 8 6 8 4 8 4

样例解释:

数列前 2 项为 2 和 3。从 2 开始,因为 2×3=6,所以第 3 项是 6。因为 3×6=18,所以第 4、5 项分别是 1、8。依次类推…… 最后因为第 6 项有 6×8=48,对应第 10、11 项应该是 4、8。而因为只要求输出前 10 项,所以在输出 4 后结束。

#include<stdio.h>
int main()
{
    int a,b,n,x,i,m[1000],j=1,k;
    scanf("%d%d%d",&a,&b,&n);
    m[0]=a;m[1]=b;
    k=1;
    for(i=0,j=1; k<=n-1 ;i++,j++)
    {
        x=m[i]*m[j];
        if(x<10){k++;m[k]=x;}
        else 
        {
           k++;m[k]=x/10;k++;m[k]=x%10;
        }
    }
    
    for(k=0;k<n;k++)
    {
        printf("%d",m[k]);
        if(k!=n-1)printf(" ");
    }
}

总结:这道题 不是很难但是再写 这道题的过程中我还是很有收获的 又一个设置多个变量 i j 用来遍历数组 k 用来往数组里 加新的元素。

posted @ 2021-07-20 17:02  日月既往、不复可追。  阅读(283)  评论(0编辑  收藏  举报
Fork me on GitHub /*音乐*/ 1 2 3
4