让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例1:
234
输出样例1:
BBSSS1234
输入样例2:
23
输出样例2:
SS123
思路:
本题思路很简单,对输入数字分出个、十、百位,再按要求输出即可。
Dinger的代码:
#include<iostream>
using namespace std;
int main(){
int number;
string hundred;
string ten;
string one;
cin>>number;
for(int i=0;number>0;i++){
if(i==0){
for(int j=0;j<number%10;j++){
one.push_back(j+49);
}
}
else if(i==1){
for(int j=0;j<number%10;j++){
ten.push_back('S');
}
}
else{
for(int j=0;j<number%10;j++){
hundred.push_back('B');
}
}
number/=10;
}
string answer = hundred+ten+one;
cout<<answer;
}
some技巧:
通过参考其他博主的解法,发现大家的思路基本相同,在本题的细节上还可以改进,比如在代码段:
for(int j=0;j<number%10;j++){
one.push_back(j+49);
}
其实可以直接进行输出,没必要再开辟一个数组进行存储了,这是一个小细节,大家注意到即可
参考博客:
参考博客1
参考博客2
参考博客3
参考博客4
参考博客5
参考博客6
something else:
喜欢的小伙伴多多点赞关注哦,对博客内容有疑问或者有其他好的解法的小伙伴积极评论哦,我将持续更新见到的更加新颖更加高效的算法分享给大家,我们一起学习一起进步!