讀入一個(gè)自然數(shù)n,計(jì)算其各位數(shù)字之和,用漢語(yǔ)拼音寫(xiě)出和的每一位數(shù)字。
輸入格式:每個(gè)測(cè)試輸入包含1個(gè)測(cè)試用例,即給出自然數(shù)n的值。這里保證n小于10100。
輸出格式:在一行內(nèi)輸出n的各位數(shù)字之和的每一位,拼音數(shù)字間有1 空格,但一行中最后一個(gè)拼音數(shù)字后沒(méi)有空格。
輸入樣例:
1234567890987654321123456789
輸出樣例:
yi san wu
package review_Test;
import java.util.Scanner;
import java.util.Stack;
public class P_1002 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String s = in.nextLine();//接受字符串?dāng)?shù)字
in.close();
int sum = 0;
for (int i = 0; i < s.length(); i++) {
sum += s.charAt(i) - '0';//charAt()返回當(dāng)前位置的字符
}
Stack<String> stack = new Stack<String>();//后進(jìn)先出
do {
int unit;
unit = sum % 10;//從右往左取每一位
switch (unit) {
case 0:
stack.push("ling");
break;
case 1:
stack.push("yi");
break;
case 2:
stack.push("er");
break;
case 3:
stack.push("san");
break;
case 4:
stack.push("si");
break;
case 5:
stack.push("wu");
break;
case 6:
stack.push("liu");
break;
case 7:
stack.push("qi");
break;
case 8:
stack.push("ba");
break;
case 9:
stack.push("jiu");
break;
}
sum /= 10;
} while (sum != 0);
System.out.print(stack.pop());
while (!stack.isEmpty()) {
System.out.print(" " + stack.pop());
}
}
}```