【算法笔记】B1006 换个格式输出整数

1006 换个格式输出整数 (15 分)

让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12...n 来表示不为零的个位数字 n<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。

输入格式:

每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。

输出格式:

每个测试用例的输出占一行,用规定的格式输出 n。

输入样例 1:

234

输出样例 1:

BBSSS1234

输入样例 2:

23

输出样例 2:

SS123

分析:
统计各位上的数(要判断是个、十、百哪一位),然后把数字转化即可。

code:

#include<iostream>
#include<string>
using namespace std;

void turn(int a,int b,int c){
    while(a!=0){cout<<"B";a--;}
    while(b!=0){cout<<"S";b--;}
    for(int i=0;i<c;i++){cout<<i+1;}
}
int main(){
    string s;
    int a=0,b=0,c=0; //a是百位,b是十位,c是个位
    cin>>s;
    if(s.length()==1){
        c = s[0]-'0';
    }
    else if(s.length()==2){
        b = s[0]-'0';
        c = s[1]-'0';
    }
    else if(s.length()==3){
        a = s[0]-'0';
        b = s[1]-'0';
        c = s[2]-'0';
    }
    //cout<<a<<b<<c<<endl;
    turn(a,b,c);
    return 0;
}

猜你喜欢

转载自www.cnblogs.com/chunlinn/p/10497507.html