本题难度:简单
一、题干
让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
二、解题思路
1.读入提供的数字
2.建立数组:利用while循环计算提供数字的位数,建立数组,利用for循环读入每一位的数字
3.利用for循环对数字进行转化输出
三、代码
// 1006 换个格式输出整数
#include <stdio.h>
int main(){
int n,i,j;
scanf("%d",&n);
int temp = n;
int bit = 0;
while(temp!=0){
temp = temp/10;
bit++;
}
int bitv[bit];
temp = n;
for(i=0;i<bit;i++){
bitv[i]=temp%10;
temp = temp/10;
}
for(i=bit-1;i>=0;i--){
if(i==2){
for(j=0;j<bitv[i];j++){
printf("B");
}
}
if(i==1){
for(j=0;j<bitv[i];j++){
printf("S");
}
}
if(i==0){
for(j=1;j<=bitv[i];j++){
printf("%d",j);
}
}
}
}