让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:
234
输出样例1:
BBSSS1234
输入样例2:
23
输出样例2:
SS123
代码:
#include <cstdio>
int main()
{
int ans[3],i,j,num,n=0; //先定义一个存放输入数字的数组,输入的数字和计数n,循环变量i,j
scanf("%d",&num);
while(num!=0) //此操作:把num中的数字分别存放放到数组ans中
{
ans[n]=num%10;
n++;
num= num/10;
}
for(i=n-1;i>=0;i--) //倒叙输出
{
if(i==2) //百位的话: 输入B
{
for(j=0;j<ans[i];j++)
{
printf("B");
}
}
else if(i==1) //十位的话:输出S
{
for(j=0;j<ans[i];j++)
{
printf("S");
}
}
else
{
for(j=1;j<=ans[i];j++) //个位的话:从1输出
{
printf("%d",j);
}
}
}
printf("\n");
return 0;
}
结果: