PAT for Java:02-拼音读和(NumberPinYin)

本文介绍了一种算法,该算法接收一个大整数作为输入,计算其所有位数的和,并将结果转换为对应的汉语拼音。通过使用Java的Scanner类进行输入处理,将整数的每一位相加得到总和,然后将总和的每一位数字转换成拼音输出。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目源地址:https://pintia.cn/problem-sets/994805260223102976/problems/type/7

拼音读和(NumberPinYin):

读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:
每个测试输入包含 1 个测试用例,即给出自然数 n 的值。这里保证 n 小于 10^100

输出格式:
在一行内输出 n 的各位数字之和的每一位,拼音数字间有 1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:
1234567890987654321123456789
输出样例:
yi san wu

代码:

import java.util.Scanner;

/*
 * 读入一个正整数 n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

 */
public class NumberPinYin {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		String str = sc.nextLine();
		int sum = 0;
		for (int i = 0; i < str.length(); i++) {
			sum += Integer.parseInt(str.charAt(i) + "");
		}
		str = sum + "";
		for (int i = 0; i < str.length(); i++) {
			if (i == str.length() - 1) {
				switch (str.charAt(i)) {
				case '1':
					System.out.print("yi");
					break;
				case '2':
					System.out.print("er");
					break;
				case '3':
					System.out.print("san");
					break;
				case '4':
					System.out.print("si");
					break;
				case '5':
					System.out.print("wu");
					break;
				case '6':
					System.out.print("liu");
					break;
				case '7':
					System.out.print("qi");
					break;
				case '8':
					System.out.print("ba");
					break;
				case '9':
					System.out.print("jiu");
					break;
				case '0':
					System.out.print("ling");
					break;
				default:
					break;
				}
			} else {
				switch (str.charAt(i)) {
				case '1':
					System.out.print("yi ");
					break;
				case '2':
					System.out.print("er ");
					break;
				case '3':
					System.out.print("san ");
					break;
				case '4':
					System.out.print("si ");
					break;
				case '5':
					System.out.print("wu ");
					break;
				case '6':
					System.out.print("liu ");
					break;
				case '7':
					System.out.print("qi ");
					break;
				case '8':
					System.out.print("ba ");
					break;
				case '9':
					System.out.print("jiu ");
					break;
				case '0':
					System.out.print("ling ");
					break;
				default:
					break;
				}
			}
		}
		sc.close();
	}

}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值