让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
/*
题目初解:
题目输入的n是一个三位数,取数位上的数就比较简单。
考虑特殊情况比如200,230这种末尾含0的数,
200:BB
230:BBSSS 为0不用输出;
234:BBSSS1234
这里只要逐位取数换个形式输出即可。
234为例,一般取余得到的顺序为
4 3 2,但是输出是从2开始输出,可以考虑用一个数组存放,
然后倒着输出就可以,本题比较简单。
*/
#include<iostream>
using namespace std;
int main(){
int n;
cin>>n; //输入n;
int Data[3]={0,0,0}; //存放个位数,不是三位数对应的数字为0;
int i=0; //循环变量
while(n!=0){
Data[i++]=n%10;
n/=10;
}
//倒序输出;当Data中数据为0时,循环中不会输出;j=0,Data[i]=0;不会进入循环
for(int i=2;i>=0;i--){
if(i==2){
for(int j=0;j<Data[i];j++){
cout<<"B";
}
}
else if(i==1){
for(int j=0;j<Data[i];j++){
cout<<"S";
}
}
else if(i==0){
for(int j=0;j<Data[i];j++){
cout<<j+1; //这里注意j是从零开始的,因此要加1;
}
}
}
return 0;
}
/*
解题反思:
这里要注意个位数字虽然计数是从零开始,0-9有十个,但是自然数输出注意是
从1开始的。
*/