让我们用字母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,用变量k来表示当前数字的位数,即需要输出“百”、“十”还是“12...n“,变量num表示当前位数有多少个,即需要输出多少个百、十还是个位数。
代码如下:
#include "stdio.h"
#include "string.h"
int main()
{
int num,i,k;
char str[4];
scanf("%s",str);
k = strlen(str);
while (k>0)
{
num = str[strlen(str)-k]-'0';
switch (k)
{
case 1:
for (i=1;i<=num;i++)
{
printf("%d",i);
}break;
case 2:
for (i=1;i<=num;i++)
{
printf("S");
}break;
case 3:
for (i=1;i<=num;i++)
{
printf("B");
}break;
}
k--;
}
return 0;
}