换个格式输出整数
让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
分析:
首先要将数字分隔开这里我们用%处理
其次我们要将分隔开的数字处理这里我们使用i作为旗子
最后我们要是用倒序输出这里注意k要减一
代码如下:
#include<stdio.h>
int main(void)
{
char a[1000000];
int n,l,j,m,i=1,k;
scanf("%d",&n);
while(n!=0)
{
j=n%10;
n=n/10;
m=j;
if(i==1)
{
for(k=0;k<m;k++)
{
switch(j)
{
case 1:a[k]='1';break;
case 2:a[k]='2';break;
case 3:a[k]='3';break;
case 4:a[k]='4';break;
case 5:a[k]='5';break;
case 6:a[k]='6';break;
case 7:a[k]='7';break;
case 8:a[k]='8';break;
case 9:a[k]='9';break;
}
j--;
}
}
if(i==2)
{
for(l=j;l>0;l--)
{
a[k]='S';
k++;
}
}
if(i==3)
{
for(l=j;l>0;l--)
{
a[k]='B';
k++;
}
}
i++;
}
for(k=k-1;k>=0;k--)
{
printf("%c",a[k]);
}
return 0;
}