1006 换个格式输出整数
分数 15
作者 CHEN, Yue
单位 浙江大学
让我们用字母 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
看这道题的时候一直在想能不能扩展到万,万幸终于写了出来
写的不周到的还请大家多多指教
#include <stdio.h>
int main()
{
int n = 0;
scanf("%d", &n);//输入
int arr[100] = { 0 };
int i = 0;//初始化
while (n != 0)
{
arr[i] = n % 10;
n = n / 10;
i++;//去位,将各个位放入位数数组
}
int d = i;//防止i的冲突
//****为了与字符数组对应****,所以要进行补位操作。这样万就能对应万,千就能对应千,如果千位为0就会在接下来循环0次,符合题意
while (5 - d)//(5+1-(i+1)) 本来i+1应该是i的,但是上面用于去位的i++多了一次,本来比如123,存以 3 2 1,但由于数组强制赋0(见下),使得存的值
//变成了3 2 1 0,所以已经占用的位数是i+1;
//本来的总体是5('W','Q','B','S','\0')位,现在就要相应的变成6位('0','W','Q','B','S','\0')
{ //所以要补的位就要用总的减去已经被占的
i++;//数组强制赋0:因为已经有了arr这个数组,每一次的i++都会强制使得arr[i]变为0。
d++;//循环5-d次
}
char arr1[5] = { 'W','Q','B','S','\0' };//创建与位数数组对应的字符数组,以便用下面的for和while循环嵌套输出
for (int k = i - 1; k >= 1; k--)//逆序位数数组。因为例如523 放进去的顺序却是从个位开始 3 2 5,所以要逆序。
//用i-1是为了排除掉前位0,k>=1是为了排除掉个位(见题意) 0 1 2
{
while (arr[k])//循环arr[k]次,根据题意,那一位上是几就要打印几次
{
printf("%c", arr1[i-1-k]);//arr i-1(万) i-2(千) k
arr[k]--; //arr1 0 1 i-1-k
}
}
for (int i = 1; i < arr[0] + 1; i++)//打印个位
{
printf("%d", i);
}
return 0;
}