发表在专栏“PAT乙级题目详解”,并在持续更新中。
https://blog.csdn.net/column/details/23947.html
让我们用字母B来表示“百”、字母S表示“十”,用“12...n”来表示个位数字n(<10),换个格式来输出任一个不超过3位的正整数。例如234应该被输出为BBSSS1234,因为它有2个“百”、3个“十”、以及个位的4。
输入格式:每个测试输入包含1个测试用例,给出正整数n(<1000)。
输出格式:每个测试用例的输出占一行,用规定的格式输出n。
输入样例1:
234
输出样例1:
BBSSS1234
输入样例2:
23
输出样例2:
SS123
分析:
这道题很简单,简单的点在于位数是确定的或者说比较容易确定的,最多三位,最少一位,这样一来,就把难度大大降低了。
#include <iostream>
using namespace std;
int main()
{
int n;
cin >> n;
int hundreds = 0;//百位
int tens = 0;//十位
int ones = 0;//个位
//如果是三位数
if (n >= 100)
{
hundreds = n / 100;
tens = (n - hundreds * 100) / 10;
ones = n - hundreds * 100 - tens * 10;
}
//如果是两位数
else if (n < 100 && n >= 10)
{
hundreds = 0;
tens = n / 10;
ones = n - tens * 10;
}
//如果是个位数
else if (n < 10 && n >= 0)
{
hundreds = 0;
tens = 0;
ones = n ;
}
//输出
for (int i = 0; i < hundreds; i++)
{
cout << "B";
}
for (int i = 0; i < tens; i++)
{
cout << "S";
}
for (int i = 0; i < ones; i++)
{
cout << i+1;
}
return 0;
}
版权声明:本文为piaoliangjinjin原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。