数的读法

11 篇文章 1 订阅

BASIC-20 数的读法

1. 题目

image.png

2. 代码

package BasicLQ;

import java.util.Scanner;
/**
 * 数的读法	判断		函数
 * @author 张辉
 *
 */
public class Basic20 {
	public static String[] nums = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
	public static String[] unit = {"shi","bai","qian","wan","yi"};
	public static int flag = 0;
	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);
		int n = sc.nextInt();
		sc.close();
		StringBuilder result = new StringBuilder();
		int p = 0;
		int q = n;
		if (n == 0) {
			System.out.println(nums[0]);
		}
		if (n > 99999999) {
			p = q / 100000000; // 要使用的
			q = q % 100000000;
			add(result,p,1);
			result.append(unit[4]+" ");
		}
		if (n > 9999) {
			p = q / 10000; // 要使用的
			q = q % 10000;
			add(result,p,2);
			if ( p != 0) {
				result.append(unit[3]+" ");
			}
		}
		if (n > 0) {
			add(result,q,3);
		}
		System.out.println(result);
	}
	public static void add(StringBuilder str,int n,int io) {
//		io 用来控制10000出现的ling
		int p = 0;
		int q = n;
		if (q > 999) {
			p = q / 1000;
			q = q % 1000;
			str.append(nums[p] + " ");
			str.append(unit[2] + " ");
			flag = 1;
		}else if (flag == 1) {
			str.append(nums[0] + " ");
			flag = 0;
		}
		if (q > 99) {
			p = q / 100;
			q = q % 100;
			str.append(nums[p] + " ");
			str.append(unit[1] + " ");
			flag = 1;
		}else if (flag == 1) {
			str.append(nums[0] + " ");
			flag = 0;
		}
		if (q > 9) {
			p = q / 10;
			q = q % 10;
			if (p == 1) {
				str.append(unit[0] + " ");
			}else {
				str.append(nums[p] + " ");
				str.append(unit[0] + " ");
			}
			flag = 1;
		}else if (flag == 1) {
			str.append(nums[0] + " ");
			flag = 0;
		}
		if (q > 0) {
			str.append(nums[q] + " ");
			flag = 1;
		}else if (flag == 1) {
			str.append(nums[0] + " ");
			flag = 0;
		}
		if (flag == 0 && n > 0) {
			int strLength = str.length(); // 计算出来的是索引。
			str.delete(strLength - 5, strLength);
		}
		if (n == 0 && io == 3) {
			int strLength = str.length(); // 计算出来的是索引。
			str.delete(strLength - 5, strLength);
		}
	}
}

3. 理解

对于这个题目,首先就是将这个数分为三层:亿、万、个位。

然后将每层分别处理:也就是处理四层。

处理到这儿就会出现一个问题,怎么控制每层的 ling 的出现。这儿有两种处理方法:

  1. 设置一个标志性全局变量,通过它来控制首位 ling 的出现。
  2. 然后就是最后一位出现的 ling ,这个 ling 的处理就是考虑从末尾删除。
  3. 还有如果第三层全部出现的是 0 ,为了顾及第二层,所以第三层必须重新定义 0 的处理方法。我的处理方法是传递一个参数进去,来确定是那一层传递进来的。

这儿遇到几个知识点:

  1. 首先就是StringBuilder怎么删除字符段:str.delete(start,end)
  2. 字符串的长度包括空格。
对于一个n,我们可以将其拆分成若干组位相同的字,然后读出每一组字的值和单位。例如: - 对于 123456789,我们可以将其拆分成 1 亿,2345 万,6789。 - 对于 200000,我们可以将其拆分成 2 十万。 具体的读法可以参考以下规则: - 对于 1~9 的字,直接读出其汉字,如 1 读作“一”,9 读作“九”。 - 对于 10~99 的字,读出十位的汉字,如果个位不为 0,则加上个位的汉字,如 22 读作“二十二”,55 读作“五十五”。 - 对于 100~999 的字,读出百位的汉字,如果十位为 0,则只读出“几百”,否则在“几百”后加上十位和个位的汉字,如 234 读作“二百三十四”,707 读作“七百零七”。 - 对于 1000~9999 的字,读出千位的汉字,如果百位为 0,则只读出“几千”,否则在“几千”后加上百位、十位和个位的汉字,如 5678 读作“五千六百七十八”。 - 对于 10000~99999 的字,读出万位的汉字,如果千位为 0,则只读出“几万”,否则在“几万”后加上千位、百位、十位和个位的汉字,如 12345 读作“一万二千三百四十五”。 - 对于 100000~999999 的字,读出十万位的汉字,如果万位为 0,则只读出“几十万”,否则在“几十万”后加上万位、千位、百位、十位和个位的汉字,如 234567 读作“二十三万四千五百六十七”。 - 对于 1000000~99999999 的字,读出百万位的汉字,如果十万位为 0,则只读出“几百万”,否则在“几百万”后加上十万位、万位、千位、百位、十位和个位的汉字,如 12345678 读作“一千二百三十四万五千六百七十八”。 - 对于 100000000~999999999 的字,读出亿位的汉字,如果百万位为 0,则只读出“几亿”,否则在“几亿”后加上百万位、十万位、万位、千位、百位、十位和个位的汉字,如 987654321 读作“九亿八千七百六十五万四千三百二十一”。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值