7-15 乘法口诀数列

分数 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 后结束。

代码长度限制

16 KB

时间限制

400 ms

内存限制

64 MB

#include<iostream>

using namespace std;
const int N=1e5;
int a[N];


int main(){
	int a1,a2,n;
	cin>>a1>>a2>>n;
	int i=3;
	a[1]=a1;
	a[2]=a2;
	if(n<=2){
		for(i=1;i<=n;i++)cout<<a[i]<<" \n"[i==n];
	}else{
		int t=3;
		
		for(int cnt=1;cnt<=n;cnt++){
		a[i]=a[t-1]*a[t-2];
		if(a[i]>9){
			a[i+1]=a[i]%10;
			a[i]=a[i]/10;
			i++;
		}
		i++;
		
		t++;
		
		cout<<a[cnt]<<" \n"[cnt==n];
		
		}
	
	
	}

	
	
} 

### L1-0080 乘法口诀数列算法实现 #### 算法描述 该问题的核心在于通过模拟的方式生成一个由初始两个数字 `a1` 和 `a2` 开始的序列 `{an}`。具体规则如下: 从第一个数字开始,依次计算当前项与其下一项的乘积,并将结果按位拆分加入到序列中。如果乘积是一个两位数,则需分别将其十位和个位作为独立的两项加入序列。 为了高效存储动态增长的数据结构,可以采用 C++ 中的 `std::vector<int>` 或者其他编程语言中的类似数据容器来保存生成的序列[^2]。 以下是基于上述逻辑的具体实现: --- #### C++ 实现代码 ```cpp #include <iostream> #include <vector> using namespace std; int main() { int a1, a2, n; cin >> a1 >> a2 >> n; // 输入三个参数 vector<int> sequence; // 使用向量存储序列 sequence.push_back(a1); sequence.push_back(a2); for (int i = 1; sequence.size() <= n && i < sequence.size(); ++i) { int product = sequence[i - 1] * sequence[i]; if (product >= 10) { // 如果乘积大于等于10,分解成两位数 sequence.push_back(product / 10); // 十位部分 sequence.push_back(product % 10); // 个位部分 } else { // 否则直接添加单个数字 sequence.push_back(product); } if (sequence.size() > n) break; // 控制长度不超过n } // 输出前n个元素 cout << sequence[0]; for (int i = 1; i < min((int)n, (int)sequence.size()); ++i) { cout << " " << sequence[i]; } return 0; } ``` --- #### Python 实现代码 Python 的列表操作非常方便,因此可以用更简洁的方式来完成相同功能: ```python def generate_sequence(a1, a2, n): seq = [a1, a2] while len(seq) < n: product = seq[-2] * seq[-1] if product >= 10: # 将两位数分开 seq.extend([product // 10, product % 10]) else: seq.append(product) if len(seq) >= n: break return seq[:n] if __name__ == "__main__": a1, a2, n = map(int, input().split()) result = generate_sequence(a1, a2, n) print(" ".join(map(str, result))) ``` --- #### 关键点解析 1. **输入范围验证** 题目规定了 `a1`, `a2` 是小于等于9的一位正整数,而 `n` 则限定在 `[1, 10^3]` 范围内[^5]。这使得我们可以放心假设不会遇到超出预期的情况。 2. **乘积处理方式** 当两数相乘得到的结果超过9时,需要特别注意如何分离出每一位并正确插入至最终序列中。例如,当乘积为17时,应该先插入1再插入7[^4]。 3. **边界条件控制** 序列的增长速度可能较快,在某些情况下甚至会提前达到目标长度 `n`。此时应当及时终止循环以免浪费资源或引发错误行为[^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值