大致思路
- 输入的数字存储为字符串,每次取一位进行判断,数字转中文的话可以通过所取的数字字符和’0’作差再加上字符’a’,可以得到对应的a-j的ascall码,将其储存
- 九位数字跟着的单位从个位到最高位依次可以存储在一个数组里面,将数字转换成对应的中文数字后,按照循环的i作为下标去取出来存入内存
关键点
- 从哪里开始循环。从个位开始循环的话,对于0的处理比较麻烦,要考虑末尾0的个数,从最高位开始的话,末尾0的情况可以和连续0的情况合为一种情况,因为我们选择从高位开始循环;此外,为了便于处理万位的情况,我们要将高位储存在字符串右边(这样的话万位下标才不管输入的数字有多少位都从4开始)
- 每个字符两种情况0或非0,非0的话就按照转换为对应中文数字并拿出对应的单位处理,0的话需要考虑连续0只输出一个0的情况,通过观察本位后面的一位是否为0来进行是否输出’a’的判断
- 万位的特殊情况,假设万位(i=4)为0的话,十万位、百万位和千万位只要有一个不为0就得输出字符’W’
- 代码如下:
import java.util.Scanner;
import java.lang.Math;
public class Main {
public static void main (String [] args) {
Scanner sc = new Scanner(System.in);
//输入的数字高位在左边,需要进行反转使其在右边
String t = new StringBuffer(sc.nextLine()).reverse().toString();
int len = t.length();
//从个位开始对应的单位,\0代表不输出任何单位
String [] str = {"\0","S","B","Q","W","S","B","Q","Y"};
StringBuffer sb = new StringBuffer();
//输出为0的情况需要单独考虑
if (t.equals("0")) {
sb.append('a');
}
//从高位开始循环,依次递减
for (int i = len - 1; i >= 0; i--) {
//取出的数字不为0的情况
if (t.charAt(i) != '0') {
sb.append((char)(t.charAt(i) - '0' + 'a')); //转换成对应的中文数字
sb.append(str[i]); //取出数组中对应的单位
} else if (i == 4) { //考虑万位上正好为0是否输出W的情况,该判断需要在下一个判断之前,不然10001234这类的情况会出现错误
if (t.charAt(5) != '0' || t.charAt(6) != '0' || t.charAt(7) != '0') {
sb.append('W');
}
}else if (i - 1 >= 0 && t.charAt(i - 1) != '0') {
//处理连续为0的情况,若两个条件都满足代表连续出现的0为中间0,只需要输出一个a,若前者不满足则代表是末尾0,不需要输出a
sb.append('a');
}
}
System.out.println(sb.toString());
}
}
参考文章:[https://blog.csdn.net/weixin_51008866/article/details/118995679]