让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:234输出样例1:
BBSSS1234输入样例2:
23输出样例2:
SS123
分析:很简单,先读入正整数,接着把正整数各位上的数字存入数组。然后循环,如果是百位,输出百位上数字个B,如果是十位,输出十位上数字个S,如果是个位,输出1-个位上的数字。
下列代码运行于VS2015,要在PAT上运行,只要将scanf_s改成scanf即可。
#include<stdio.h>
int main(void) {
int n=0;
int temp = 0;
int value[4],count=0;
int i;
scanf_s("%d", &n);
temp = n;
while (temp > 0) {
value[count++] = temp % 10;
temp /= 10;
}
while (count-- > 0) {
if (count == 0)
for (i = 1; i <= value[count]; i++)
printf("%d", i);
else if (count == 2)
for (i = 0; i < value[count]; i++)
printf("%c", 'B');
else if (count == 1)
for (i = 0; i < value[count]; i++)
printf("%c", 'S');
}
return 0;
}