PAT:B1002 写出这个数(20 分)
读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。
输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10100。
输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。
输入样例:
1234567890987654321123456789
输出样例:
yi san wu
思路:
1.先用char类型去接收该大数字
2.char类型的数据转成数字
3. 用a去接收所有的数字之和,然后转成数组
代码:
C/C++:
#include<cstdio>
#include<string>
#include<iostream>
using namespace std;
char pin[10][5] = {"ling", "yi", "er", "san", "si", "wu", "liu", "qi", "ba", "jiu"};
int main() {
string str;
cin >> str;
int count = 0;
for(int i = 0; i < str.length(); i++) {
count += str[i] - '0';
}
int a[10] = {0}, j = 0;
while(count != 0) {
a[j++] = count % 10;
count = count / 10;
}
for(int i = j-1; i >= 0; i--) {
printf("%s", pin[a[i]]);
if(i != 0) printf(" ");
}
return 0;
}
Java:
import java.util.Scanner;
public class Main {
static int maxn = 110;
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String[] py = new String[10];
py[0] = "ling"; py[1] = "yi"; py[2] = "er"; py[3] = "san"; py[4] = "si";
py[5] = "wu"; py[6] = "liu"; py[7] = "qi"; py[8] = "ba"; py[9] = "jiu";
String str;
str = in.nextLine();
int a = 0;
for(int i = 0; i < str.length(); i++) {
a += str.charAt(i) - '0';
}
int[] array = new int[10];
int j = 0, k = 0;
while (a != 0) {
array[j++] = a % 10;
a = a / 10;
}
for (int i = j - 1; i >= 0; i--) {
System.out.print(py[array[i]]);
if(i != 0) {
System.out.printf(" ");
}
}
}
}