美文网首页
JZ-068-打印从 1 到最大的 n 位数

JZ-068-打印从 1 到最大的 n 位数

作者: 醉舞经阁半卷书 | 来源:发表于2022-02-22 19:28 被阅读0次

    打印从 1 到最大的 n 位数

    题目描述

    输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数即 999。

    题目链接: 打印从 1 到最大的 n 位数

    代码

    /**
     * 标题:打印从 1 到最大的 n 位数
     * 题目描述
     * 输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数即 999。
     * 题目链接:
     */
    public class Jz68 {
    
        /**
         * 由于 n 可能会非常大,因此不能直接用 int 表示数字,而是用 char 数组进行存储。
         */
        public void print1ToMaxOfNDigits(int n) {
            if (n <= 0) {
                return;
            }
    
            char[] number = new char[n];
            print1ToMaxOfNDigits(number, 0);
        }
    
        private void print1ToMaxOfNDigits(char[] number, int digit) {
            if (digit == number.length) {
                printNumber(number);
                return;
            }
            for (int i = 0; i < 10; i++) {
                number[digit] = (char) (i + '0');
                print1ToMaxOfNDigits(number, digit + 1);
            }
        }
    
        private void printNumber(char[] number) {
            int index = 0;
            while (index < number.length && number[index] == '0') {
                index++;
            }
            while (index < number.length) {
                System.out.print(number[index++]);
            }
            System.out.println();
        }
    
        public static void main(String[] args) {
            Jz68 jz68 = new Jz68();
            jz68.print1ToMaxOfNDigits(3);
        }
    }
    

    【每日寄语】 昔孟母,择邻处;子不学,断机杼。

    相关文章

      网友评论

          本文标题:JZ-068-打印从 1 到最大的 n 位数

          本文链接:https://www.haomeiwen.com/subject/kwaglrtx.html