题目要求:让我们用字母B来表示“百”、字母S表示“十”,用“12…n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例:
234
输出样例1:
BBSSS1234
输入样例2:
23
输出样例2:
SS123
解题思路:我们应该将输入的一个小于1000的数的每个位进行拆解,然后根据每个位的大小选择相应的模式进行输出
#include <iostream>
using namespace std;
int main()
{
int cin_a; //存储输入的数值
int a[3] = {0}; //存储每个位
cin >> cin_a;
int i=0;
//对输入的数,即cin_a进行拆解
while(cin_a)
{
a[i] = cin_a %10;
cin_a = cin_a/10;
i++;
}
//百位数 输出
if(a[2]!=0)
for(int i=0;i<a[2];i++)
cout <<"B";
//十位数 输出
if(a[1]!=0)
for(int i=0;i<a[1];i++)
cout <<"S";
//个位数 输出
if(a[0]!=0)
for(int i=1;i<=a[0];i++)
cout << i;
return 0;
}