JavaBean字符串训练(支票大写)

复制代码
package 字符串练习;

import java.util.Scanner;

public class 人名币训练 {
    public static void main(String[] args) {
        /* 需求: 用户输入一个数字,改成发票那样的展示出来
           例子: 4321 -> 零佰零拾零万肆千叁佰贰拾壹元
            共七位(固定)
         */
        //思路: 1. 把用户读入的数字改写成大写,并用字符串拼接起来
        //      2. 计算用户读入数字的位数
        //      3. 在字符串前面补零(个数 = 7 - 用户读入的数字位数)
        //      4. 再定义好单位名,两个string数组再同时拼接就ok了

        int user_input_number = user_input();
        //读入完毕

        String upper_user_input_Reverse = upper_chinese(user_input_number);
        //大写字符串完毕(反向)

        String upper_forward_user_input_number = forware_use_input_upper(upper_user_input_Reverse);
        //正向用户读入数字大写字符串准备完毕

        upper_forward_user_input_number = add_zero(upper_forward_user_input_number);
        //补零完毕

        result(upper_forward_user_input_number);
    }

        public static int user_input () {
            //用户读入数据
            Scanner sc = new Scanner(System.in);
            int user_input_number = sc.nextInt();
            //读入完毕
            return user_input_number;
        }

        public static String upper_chinese ( int user_input_number ){
            //改写成大写,那就要先写好每个数字的大写汉字放到数组里
            String upper_chinese[] = {"零", "壹", "贰", "叁", "肆", "伍", "陆", "柒", "捌", "玖" };

            //想要得到每一位数字的大写,那么就先要得到每一位数字,然后数字对应大写数组索引取值就ok了
            //先定义一个空string字符串,用于拼接
            String upper_user_input_Reverse = "";

            while (user_input_number > 0) {
                upper_user_input_Reverse += upper_chinese[user_input_number % 10];
                user_input_number /= 10;
            }
            //大写字符串完毕(反向)
            return upper_user_input_Reverse;
        }

        public static String forware_use_input_upper (String upper_user_input_Reverse){
            //准备将反向改成正向
            String upper_forward_user_input_number = "";
            for (int i = upper_user_input_Reverse.length() - 1; i >= 0; i--) {
                upper_forward_user_input_number += upper_user_input_Reverse.charAt(i);
            }
            return upper_forward_user_input_number;
        }

        public static String add_zero (String upper_forward_user_input_number ){
            //计算位数
            int count = upper_forward_user_input_number.length();
            //补 零
            for (int i = count; i < 7; i++) {
                upper_forward_user_input_number = "零" + upper_forward_user_input_number;
            }
            return upper_forward_user_input_number;
        }
        public static void result(String upper_forward_user_input_number){
            //定义单位名
            char unit[] = {'佰','拾','万','千','佰','拾','元'};

            //同时拼接
            String results = "";
            for (int i = 0; i < upper_forward_user_input_number.length(); i++) {
                results = results + upper_forward_user_input_number.charAt(i) + unit[i];
            }
            System.out.println(results);
        }
}
相关推荐
Mahir082 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
杜子不疼.2 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号32 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia3 小时前
Qt——编辑交互功能的实现
开发语言·qt
RyFit3 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码3 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家3 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事3 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海4 小时前
C# 隐式转换深度解析
java·开发语言·c#
碧海银沙音频科技研究院4 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别