让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
解题思路:由于给定的数字是不超过3位的正整数,故我们可以直接计算出这个数字的个位十位和百位,若数字是个位数则百位和十位都为0,若数字是十位数,则百位为0;
其余的就注意一下如何求一个三位数的个位十位百位即可。
AC代码(C++):
#include<iostream>
using namespace std;
int main()
{
int number;
cin>>number;
int baiwei = number/100; //计算百位
int shiwei = number/10%10; //计算十位
int gewei = number%10; //计算个位
for(int i =0;i<baiwei;i++)
cout<<"B";
for(int j=0;j<shiwei;j++)
cout<<"S";
for(int k =1;k<=gewei;k++)
cout<<k;
}