让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3
位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
题目不难直接上AC代码,主要考察了对正整数的正序输出。从这道题可以看出pta对我们的考察比较基础,但却是我们经常会忽略的一个点,这题我们就要掌握整数的倒序正序输出,注意倒序是否输出零的多种情况,变式较多。
#include<stdio.h>
int main()
{
int n, b, t, count = 1;
scanf("%d",&n);
b = n;
//得到正整数的位数
while(b > 9){
count *= 10;
b /= 10;
}
//一个个正序取出正整数
do{
t = n / count;
//printf("%d\n",t);主要为了验证得到的三位数是否正确,pta可以用测试用例调试代码
if (count == 100){
for (int i = 1;i <= t;i++) printf("B");
}
else if(count == 10){
for (int i = 1;i <= t;i++) printf("S");
}
else if(count == 1){
for (int i = 1;i <= t;i++) printf("%d",i);
}
n = n % count;
count /= 10;
}while(count > 0);
return 0;
}
本题测试样例有八个,还是比较多的一道题,说明本题有很多细节要注意,毕竟测试样例都是考察不同方面的。