当前位置: 首页 > article >正文

PTA L1-080 乘法口诀数列

L1-080 乘法口诀数列(20分)

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

输入格式:

输入在一行中给出 3 个整数,依次为 a1​、a2​ 和 n,满足 0≤a1​,a2​≤9,0<n≤103。

输出格式:

在一行中输出数列的前 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 a1 = 0, a2 = 0, n = 0, t = 0;
    scanf("%d %d %d", &a1, &a2, &n);
    int arr[20050];
    if(n == 1)
        printf("%d", a1);
    else
    {
        arr[0] = a1, arr[1] = a2;
        for(int i = 2, k = 2; k != n; i++, k++)
        {
            t = arr[k-2]*arr[k-1];
            if(t <= 9)
                arr[i] = t;
            else
            {
                arr[i] = t / 10;
                arr[++i] = t % 10;
            }
        }
        for(int i = 0; i < n; i++)
        {
            printf("%d", arr[i]);
            if(i != n - 1)
                printf(" ");
        }
    }

    return 0;
}

http://www.kler.cn/a/326133.html

相关文章:

  • 在 Ubuntu 上对 Nginx 进行源码编译的详细指南
  • 【YOLOv8杂草作物目标检测】
  • Jenkins触发器--在其他项目执行后构建
  • js代理模式
  • Unity:删除注册表内的项目记录
  • Perl语言的循环实现
  • C语言线程编程深度解析
  • Elasticsearch UNASSIGNED 怎么修复
  • OJ在线评测系统 后端 用策略模式优化判题机架构
  • MySQL基础篇 - 约束
  • Eclipse Memory Analyzer (MAT)提示No java virtual machine was found ...解决办法
  • Altium Designer脚本的执行方式
  • 【漏洞复现】VEXUS多语言货币交易所存在未授权访问漏洞
  • centos已安装python3.7环境,还行单独安装python3.10环境,如何安装,具体步骤
  • 进程、线程、协程详解:并发编程的三大武器
  • websocket初识
  • 数据集-目标检测系列-兔子检测数据集 rabbit >> DataBall
  • 中国资产“超级星期四”之后,腰部中概股或成增长“黑马”
  • Linux云计算 |【第四阶段】PROJECT2-DAY1
  • 如何使用开发者工具捕获鼠标右键点击事件
  • Tensorflow2.0
  • Spring Boot 进阶-深入了解SpringBoot条件注解
  • VLAN与三层交换机的原理与配置
  • 基于单片机的小车行走加温湿度检测系统
  • 前端框架对比及选择:React、Vue、Angular的深度剖析
  • 图解C#高级教程(一):委托