1002. 写出这个数 (20)

本文介绍了一种算法,该算法能够接收一个自然数n作为输入,并计算出n的所有位数字之和。随后,该算法将这个总和的每一位数字转换成对应的汉语拼音形式输出。文章还提供了一个Java实现示例,演示了如何读取用户输入的长数字,计算数字和,并将每位数字的和转换为汉语拼音。

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

读入一个自然数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 sc = new Scanner(System.in);
 String str = sc.nextLine();
 String strSum;
 int i = 0,sum = 0;
 while(i != str.length())
 {
   sum += (int)str.charAt(i)-48;
   i++ ;
 }
 strSum = ""+sum;
 
 for(i = 0;i<strSum.length();i++)
 {
 System.out.print( Fun((int)strSum.charAt(i)-48) );
     if(i<strSum.length()-1)
   System.out.print(" ");
 }
 
  }
  
  public static String Fun(int n)
  {
 switch(n)
 {
 case 0:return "ling" ;
 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" ;
 default:return "error";
 }
 
  }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值