1006 换个格式输出整数 (15 分)
让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
每个测试用例的输出占一行,用规定的格式输出 n。
234
BBSSS1234
23
SS123
按部就班~,模拟
// luogu-judger-enable-o2
#include<bits/stdc++.h>
#include<unordered_set>
#define rg register ll
#define inf 2147483647
#define min(a,b) (a<b?a:b)
#define max(a,b) (a>b?a:b)
#define ll long long
#define maxn 300005
#define lb(x) (x&(-x))
const double eps = 1e-6;
using namespace std;
inline ll read()
{
char ch = getchar(); ll s = 0, w = 1;
while (ch < 48 || ch>57) { if (ch == '-')w = -1; ch = getchar(); }
while (ch >= 48 && ch <= 57) { s = (s << 1) + (s << 3) + (ch ^ 48); ch = getchar(); }
return s * w;
}
inline void write(ll x)
{
if (x < 0)putchar('-'), x = -x;
if (x > 9)write(x / 10);
putchar(x % 10 + 48);
}
string s;
int main()
{
cin>>s;
if(s.size()==1)
{
ll k=1;
for(rg i=1;i<=s[0]-'0';i++)
{
cout<<k;
k++;
}
}
if(s.size()==2)
{
for(rg i=1;i<=s[0]-'0';i++)
{
cout<<"S";
}
ll k=1;
for(rg i=1;i<=s[1]-'0';i++)
{
cout<<k;
k++;
}
}
if(s.size()==3)
{
for(rg i=1;i<=s[0]-'0';i++)
{
cout<<"B";
}
for(rg i=1;i<=s[1]-'0';i++)
{
cout<<"S";
}
ll k=1;
for(rg i=1;i<=s[2]-'0';i++)
{
cout<<k;
k++;
}
}
return 0;
}