原题链接:蓝桥杯基础练习VIP-数的读法
解题思路:
将读入的数字从后往前数,每四个划为一组,数字长度不够4整除的前补0使之刚好被4整除 如:1234567009,即被分成了0012,3456,7009三组 其中,第一组(从左往右数)的单位是"yi"(亿),第二组的单位是"wan"(万)(第三组的单位是1,可以不包含在结果里) 然后每组分开读数,指针i初始化指向左边第一个非零数字,依次往后扫描 对于每一组,都有如下情况: ①i%4 = 0时,处在"qian"(千)位,非0时,读出数字,再追加一个"qian" ②i%4 = 1时,处在"bai"(百)位,非0时,读出数字,再追加一个"bai" ③i%4 = 2时,处在"shi"(十)位,非0时,读出数字,再追加一个"shi" ④i%4 = 3时,处在个位,如果是0,不用读出来,如果非0,读出数字;最后不要忘了,再追加该组的单位(第三组可以不加) 大体思路就是这样,还有些细节部分没细说(如连续零的处理,"yi shi"和"shi"的处理等),大家可以直接看代码部分
注意事项:
1.一般情况下,连续的零只需读出一个(特殊情况下,即使有连续的零也不需要读出,如1000003000(shi yi san qian))
2.shi还是yi shi的处理
3.末尾可以有一个多余的空格
参考代码:
import java.util.Scanner;
public class T1469 {
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
String digit[] = {"ling","yi","er","san","si","wu","liu","qi","ba","jiu"};
while(in.hasNext()) {
String n = in.next();
int cnt = n.length()%4;
String tmp[] = {"0000","000","00","0"};
n = tmp[cnt]+n; //把输入的数字拼成4的整数倍长度
String ans = "";
int nzero = 0; //记录连续0的个数
for(int i =4-cnt;i<n.length();i++) {//4-cnt可定位到输入数字的第一位
if(n.charAt(i) != '0') {
//遇到第一个非零数字,且有多个连续的0,且非零数字不在下一组的第一个位置,只需读出一个0
if(nzero>0 && i%4 != 0)
ans += "ling ";
nzero = 0;
if(i%4==0) //千位
ans += digit[n.charAt(i)-'0'] + " qian ";
else if(i%4==1) //百位
ans += digit[n.charAt(i)-'0'] + " bai ";
else if(i%4==2) //十位
ans += digit[n.charAt(i)-'0'] + " shi ";
else //个位
ans += digit[n.charAt(i)-'0'] + " ";
}
else
nzero++;
if(n.length() - i == 5 && nzero < 4)//如果位于万位上且这一组的四个数字不全为0,需要加“wan”
ans += "wan ";
else if(n.length() - i == 9)//如果位于亿位上,需要加“yi”
ans += "yi ";
}
if(ans.indexOf("yi shi") == 0) //"yi shi"开头的话要去掉"yi "
ans = ans.substring(3,ans.length());
System.out.println(ans);
}
in.close();
}
}0.0分
9 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复