1006 换个格式输出整数 (15分)

让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12...n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。

输入格式:

每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。

输出格式:

每个测试用例的输出占一行,用规定的格式输出 n

输入样例 1:

1
234

输出样例 1:

1
BBSSS1234

输入样例 2:

1
23

输出样例 2:

1
SS123

思路:

非常简单的一道题,从个位开始拆分输入的数字,最后输出即可。

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#include <iostream>
using namespace std;

int main()
{
int n, i = 0;
cin >> n;
int state[3] = {0};

while (n)
{
state[i++] = n % 10;
n /= 10;
}

for (int i = 0; i < state[2]; i++)
cout << 'B';
for (int i = 0; i < state[1]; i++)
cout << 'S';
for (int i = 0; i < state[0]; i++)
cout << i + 1;

return 0;
}