”让男友打十万个「对不起」道歉,汉字标上多少遍。如何快速检查中间没有漏?“的坚决方案

源于知乎上的这个问题https://www.zhihu.com/question/27231908
解决方案:
用数组来存储汉字,堆栈存储每次遍历到的数字需要的汉字

import java.util.Stack;

public class Main {

    static String[] values = {"零", "一", "二", "三", "四", "五", "六", "七", "八", "九"};
    static String[] pos = {"拾", "佰", "仟", "万"};
    private static Stack<String> mStack;

    public static void main(String[] args) {
        long start = System.currentTimeMillis();
        for (int i = 1; i <= 99999; i++) {
            if (i >= 10 && i < 20) {
                System.out.println("对不起 第" + change(i).substring(1) + "遍");
            } else {
                System.out.println("对不起 第" + change(i) + "遍");
            }
        }
        long end = System.currentTimeMillis();
        System.out.println("运行时间" + (end - start) + "ms");
    }

    private static String change(int i) {
        boolean flag = false;
        int len = 0;
        int num = i;
        while (i > 0) {
            i /= 10;
            len++;
        }
        if (len > 1) {
            mStack = new Stack<String>();
            for (int j = 1; j < len; j++) {
                if (numAtInteger(num, j) != 0)
                    mStack.push(pos[j - 1]);
            }
        }
        StringBuilder sb = new StringBuilder();
        for (int j = len - 1; j > 0; j--) {
            int temp = (num / ((int) Math.pow(10, j)));
            num %= ((int) Math.pow(10, j));
            if (temp != 0) {
                sb.append(values[temp]);
                sb.append(mStack.pop());
            }
            if (temp == 0 && !flag) {
                sb.append("零");
                flag = true;
            }
        }
        if (num == 0) {
            if (sb.toString().endsWith("零")) {
                return sb.substring(0, sb.length() - 1);
            }
            return sb.toString();
        } else {
            sb = sb.append(values[num]);
            return sb.toString();
        }
    }
    static int numAtInteger(int num, int j) {
        while (j > 0) {
            num /= 10;
            j--;
        }
        return num % 10;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值