读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例
1234567890987654321123456789
输出样例
yi san wu
代码实现
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String n = in.nextLine(); //这里本来要判断值是否小于10的100次方,因此无法用long或者int类型的变量来赋值
//如BigInteger
System.out.println(getStr(n));
}
public static String getStr(String strNum){
String str = "";
int sum = 0;
for (char c:
strNum.toCharArray()) {
sum += (int) c - 48; //'1'的askll码值为49,注意要将强转后的值减去48
}
char[] sumArray = Integer.toString(sum).toCharArray();
for (int i = 0; i < sumArray.length-1;i++){
str += getNum(sumArray[i]) + " ";
}
str += getNum(sumArray[sumArray.length-1]);//在最后加上一个没有空格的中文数字
return str;
}
public static String getNum(char c){
switch (c){
case '0' : return "ling"; //因为已经有return 所以不需要break,注意case后是字符而不是数字
case '1' : return "yi";
case '2' : return "er";
case '3' : return "san";
case '4' : return "si";
case '5' : return "wu";
case '6' : return "liu";
case '7' : return "qi";
case '8' : return "ba";
case '9' : return "jiu";
}
return null;
}
}