让我们用字母 B 来表示“百”、字母 S 表示“十”,用 12…n 来表示不为零的个位数字 n(<10),换个格式来输出任一个不超过 3 位的正整数。例如 234 应该被输出为 BBSSS1234,因为它有 2 个“百”、3 个“十”、以及个位的 4。
输入格式:
每个测试输入包含 1 个测试用例,给出正整数 n(<1000)。
输出格式:
每个测试用例的输出占一行,用规定的格式输出 n。
输入样例 1:
234
输出样例 1:
BBSSS1234
输入样例 2:
23
输出样例 2:
SS123
这道题不难,一开始打算判断下输入数字是几位数,后来发现根本不用,直接取模后除10就好了,n=0的时候结束,取了几次就是几位数
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
String b = "", s = "", g = "";
int count = 0;//计哪位数
while (n > 0) {
//n=0的时候结束循环
if (count == 0) {
//个位
for (int i = 0; i < n % 10; i++) {
g += (i + 1);
}
} else if (count == 1) {
//十位
s = g(n % 10, 'S');
} else {
//百位
b = g(n % 10, 'B');
}
count++;//下一位
n /= 10;
}
System.out.println(b + s + g);
}
static String g(int n, char c) {
String r = "";
for (int i = 0; i < n; i++) {
r += c + "";
}
return r;
}
}