#PAT打卡6
1006 换个格式输出整数 (15 分)
让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
##题解
###分析题意
这道题题意并不难理解,就是输入一个不为0且小于1000的数字,并有多少个100就输出多少个B,有多少个10就输出多少个S,个位数字是几就输出从1开始到该个位数的连续数字。
###要点
1.可以定义一个字符数组储存要输出的所有字符,当然也可以在下方我编写的代码中每一个存储位置直接输出对应的字符。
2.对于要求我做了while语句中嵌套了一个if判断语句,用于分别判断n>100,100>n>10,n<10,三种情况,并储存相应的字符进数组后对n进行相减的操作。
3.但在输出的时候遇到了一点小麻烦,寻找了一下发现是因为相关操作问题会导致输入部分数据后该数组最后缺少结束符,可以选择像以下代码改为一个一个字符输出,也可以在数组的末端主动定义‘/’0’.
##代码
#include<stdio.h>
int main()
{
char array[100],charnum='0';
int i=0,n,j;
scanf("%d",&n);
while(n!=0)
{
if(n>=100)
{
n=n-100;
array[i]='B';
i+=1;
}
else if(n>=10)
{
n=n-10;
array[i]='S';
i+=1;
}
else if(n>0)
{
n=n-1;
charnum+=1;
array[i]=charnum;
i+=1;
}
}
for(j=0;j<i;j++){
printf("%c",array[j]);
}
return 0;
}