本题要求你从任意给定的两个 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<iostream>
#include<vector>
#include<string>
using namespace std;
int main(){
vector<int> v;
int a1,a2,n;
cin>>a1>>a2>>n;
v.push_back(a1);
v.push_back(a2);
int sign=0;
while(v.size()<n){
int temp=v[sign]*v[sign+1];
sign++;
if(temp>=10){
string s=to_string(temp);
int size=s.size();
for(int i=0;i<size;i++){
int t=s[i]-'0';//将char转化为int
v.push_back(t);
}
}
else{
v.push_back(temp);
}
}
for(int j=0;j<n;j++){
if(j==0)cout<<v[j];
else cout<<' '<<v[j];
}
}
代码思路:
首先,定义了一个整型向量v,用来存储一系列的数字,以及三个整型变量a1,a2,n,用来接收用户的输入。
然后,使用cin>>a1>>a2>>n;语句,从标准输入流中读取三个整数,分别赋值给a1,a2,n。其中,a1和a2是向量v的初始元素,n是向量v的目标长度。
接着,使用v.push_back(a1);和v.push_back(a2);语句,将a1和a2分别添加到向量v的末尾,此时向量v的长度为2。
再然后,定义了一个整型变量sign,用来记录向量v中相邻两个元素的乘积的起始位置,初始值为0。使用while(v.size()<n);语句,创建一个循环,当向量v的长度小于n时,执行循环体内的语句。
在循环体内,首先计算向量v中下标为sign和sign+1的两个元素的乘积,赋值给一个整型变量temp。然后将sign的值加1,表示下一次乘积的起始位置向后移动一位。
接下来,判断temp的值是否大于等于10,如果是,则将temp转换为字符串s(这样可以方便将每一位剥离下来,使用%也行),获取s的长度size,然后使用一个for循环,遍历s中的每个字符,将每个字符转换为整数t,然后将t添加到向量v的末尾。这样做的目的是将temp的每一位数字作为向量v的新元素。
如果temp的值不大于10,即小于10,则直接将temp添加到向量v的末尾,就不需要转化成String了
最后,当向量v的长度达到或超过n时,退出循环。