问题描述
让我们用字母B来表示“百”、字母S表示“十”,用“12…n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:
234
输出样例1:
BBSSS1234
输入样例2:
23
输出样例2:
SS123
code
#include <stdio.h>
void coutc( int a, char c )
{
int i = 0;
for (; i < a; i++ )
printf( "%c", c );
}
void coutd( int n )
{
int i = 0;
for (; i < n; i++ )
printf( "%d", i + 1 );
}
int main()
{
int n, i = 0;
scanf( "%d", &n );
int a[2] = { 0 };
while ( n > 9 )
{
a[i++] = n % 10;
n /= 10;
}
a[i] = n;
if ( i == 2 )
coutc( a[2], 'B' ), coutc( a[1], 'S' ), coutd( a[0] );
else if ( i == 1 )
coutc( a[1], 'S' ), coutd( a[0] );
else coutd( a[0] );
return(0);
}