打印从 1 到最大的 n 位数 题目描述
输入数字 n,按顺序打印出从 1 到最大的 n 位十进制数。比如输入 3,则打印出 1、2、3 一直到最大的 3 位数即 999。代码
【JZ-068-打印从 1 到最大的 n 位数】题目链接: [打印从 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);
}
}
【每日寄语】 昔孟母,择邻处;子不学,断机杼。
推荐阅读
- Java算法|Java 实现OS调度算法之先来先服务算法(FCFS)
- Java算法|Java 实现OS调度算法之短进程优先算法(SJF)
- 选择排序,简单排序,冒泡排序,快速排序的java代码实现
- Java中反射的概念、意义、用法(适合新手阅读)
- 算法|Java算法系列3--基于链表自定义队列
- java无限级树生成算法,空间复杂度为O(2n)