题目
让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例:
234
输出样例:
BBSSS1234
分析:
一开始的想法就是将输入数字的各个数位上的数字截取再按次数输出,但觉得直接读取字符串是不是会方便些,然后就踩坑了,输入的数字不一定都是三位数,然后修改了一下成了又臭又长的代码。。
代码 :
#include <iostream>
#include <cstring>
using namespace std;
int main(){
char num[4];
cin >> num;
if(strlen(num) == 3){
for(int i = 0; i < num[0]-'0'; ++i){
cout << "B";
}
for(int i = 0; i < num[1]-'0'; ++i){
cout << "S";
}
for(int i = 0; i < num[2]-'0'; ++i){
cout << i+1;
}
}
if(strlen(num) == 2){
for(int i = 0; i < num[0]-'0'; ++i){
cout << "S";
}
for(int i = 0; i < num[1]-'0'; ++i){
cout << i+1;
}
}
if(strlen(num) == 1){
for(int i = 0; i < num[0]-'0'; ++i){
cout << i+1;
}
}
return 0;
}
我觉得优秀的代码:
#include <iostream>
using namespace std;
int main()
{
int n, b, s, g;
cin >> n;
//从高位向低位获取各位数字
b = n / 100;
s = n % 100 / 10;
g = n % 10;
for(int i = 0; i < b; i++) cout << "B";
for(int i = 0; i < s; i++) cout << "S";
for(int i = 1; i <= g; i++) cout << i;
return 0;
}
学到和回忆了:
- 字符转换为数字
- 提取各个数位数字的方法