(pat乙级1006)
让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
c++代码:
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
string word[10]={"0","1","2","3","4","5","6","7","8","9"};
int main(){
int n,a=0;
cin>>n;
string s="";
int num=0; //记录当前是哪一位(个-->十-->百)
while(n!=0){
a=n%10; //得到当前n的个位数
if(num==0){ //是个位
for(int i=a-1;i>=0;i--)s=s+word[i+1];num++;
}
else if(num==1){ //是十位
for(int i=0;i<a;i++)s=s+"S";num++;
}
else if(num==2){ //是百位
for(int i=0;i<a;i++)s=s+"B";num++;
}
n=n/10;
}
reverse(s.begin(),s.end()); //结果字符串反向
cout<<s;
return 0;
}
注意:
因为是不断n/10从n的个位向前依次得到n的每一位,所以结果字符串是反向的。调用alogrithm下的reverse(s.begin(),s.end())把字符串s反向后输出。