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
//温故知新,修改于2016.7.30
#include<iostream>
#include<string>
#include<algorithm>
using namespace std;
int main()
{
int num;
cin>>num;
string result="";
int flag=-1;
while(num!=0){
int data=num%10;
switch(flag){
case -1:
while(data--)
result+=(data+1)+'0';
break;
case 0:
while(data--)
result+='S';
break;
case 1:
while(data--)
result+='B';
break;
}
flag++;
num=num/10;
}
reverse(result.begin(),result.end());
cout<<result<<endl;
return 0;
}
#include<iostream>
#include<vector>
using namespace std;
int main()
{
cout<<"please input a Natural number(<1000)"<<endl;
int num;
cin>>num;
vector<int> result;
while(num!=0)
{
int data=num%10;
result.push_back(data);
num=num/10;
}//按照从低位到高位存储输入数据
for(int i=0;i!=result.size();i++)
{
int id=result.size()-i-1;
char newNum;
switch(id)
{
case 2:
newNum='B';
break;
case 1:
newNum='S';
break;
case 0:
newNum='g';
break;
}
for(int j=0;j<result[id];j++)
{
if(newNum=='g')
cout<<(j+1);
else
cout<<newNum;
}
}
cout<<endl;
return 0;
}