让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:
234
输出样例1:
23
输出样例2:
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:
234
输出样例1:
BBSSS1234
23
输出样例2:
SS123
解题思路:
很直观,将得到的数存入一个res数组,比如234,就是res[0] = 4;res[1] = 3; res[2] = 2;然后根据有几位数分别循环输出对应的B或S,最后循环输出个位数上的1~n。
#include <cstdio> int main() { int n, cnt = 0; int res[3]; char change[4] = {' ', ' ', 'S', 'B'}; //代表转换后的字符 scanf("%d", &n); while(n != 0) { res[cnt] = n % 10; //将每位数字逆序存入res数组 n /= 10; cnt++; //统计位数 } //百位或十位,分别输出对应数字个数的B或S while(cnt != 1) { for(int i = 0; i < res[cnt - 1]; i++) { printf("%c", change[cnt]); } cnt--; } //个位,按序输出 if(cnt == 1) { for(int i = 1; i <= res[cnt - 1]; i++) { printf("%d", i); } } return 0; }