让我们用字母 B
来表示“百”、字母 S
表示“十”,用 12...n
来表示不为零的个位数字 n
(<),换个格式来输出任一个不超过 3 位的正整数。例如 234
应该被输出为 BBSSS1234
,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
#include <stdio.h> #include <algorithm> #include <string> #include <map> #include <iostream> #include <stack> using namespace std; const int maxn = 100; int index[3] = { 0 }; int main(){ int n; cin >> n; int pos = 2; while (n != 0){ index[pos--] = n % 10; n /= 10; } for (int i = 0; i < index[0]; i++){ cout << ‘B‘; } for (int i = 0; i < index[1]; i++){ cout << ‘S‘; } for (int i = 0; i < index[2]; i++){ cout << i+1; } system("pause"); }
注意点:输入整数不一定是三位数,所以不能用getchar直接来做。用数组倒着存也就是先进后出(filo),也可以用stack,但就需要判断大小了
原文地址:https://www.cnblogs.com/tccbj/p/10359170.html
时间: 2024-10-08 21:31:23