剑指Offer(Java版)第十五题:打印1到最大的n位数

Posted 桌子哥

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指Offer(Java版)第十五题:打印1到最大的n位数相关的知识,希望对你有一定的参考价值。

/*
打印1到最大的n位数
*/
//一开始想到的是直接构造出最大数,然后逆序输出,把‘0’排除在外即可。看了一些网上的博客,要注意大叔情况,因此使用以下方法。
public class Class15 {

public void printNumber(int n){
if(n <= 0){
return;
}
char[] number = new char[n];
for(int i = 0; i < 10; i++){
number[0] = (char)(i + ‘0‘);
printNumberMain(number, n, 0);
}
}
//index表示判断是否打印的条件,如果与输入的指示相同则输出。
//使用递归的方式来进行操作
public void printNumberMain(char[] number, int length, int index){
if(index == length - 1){
print(number);
return;
}
for(int i = 0; i < 10; i++){
number[index + 1] = (char)(i + ‘0‘);
printNumberMain(number,length,index + 1);
}
}
//这里是关键,判断是否打印单个的‘0‘
public void print(char[] number){
boolean isBegin0 = true;
int length = number.length;
for(int i = 0; i < length; i++){
if(isBegin0 && number[i] != ‘0‘){
isBegin0 = false;
}
if(!isBegin0){
System.out.print(number[i]);
}
}
if(!isBegin0){
System.out.println();
}
}

public void test(int n){
printNumber(n);
}

public static void main(String[] args) {
// TODO Auto-generated method stub
Class15 c= new Class15();
c.test(2);
}

}

以上是关于剑指Offer(Java版)第十五题:打印1到最大的n位数的主要内容,如果未能解决你的问题,请参考以下文章

《剑指offer》第十五题:二进制中1的个数

剑指Offer(Java版)第四十五题:一个整型数组里除了两个数字之外,其他的数字都出现了两次。请写程序找出这两个只出现一次的数字。

剑指Offer(Java版)第六十五题:给定一棵二叉搜索树,请找出其中的第k小的结点。 例如, (5,3,7,2,4,6,8) 中,按结点数值大小顺序第三小结点的值为4。

《剑指offer》第十七题:打印1到最大的n位数

《剑指offer》第五十五题II:平衡二叉树

《剑指offer》第五题(重要!从尾到头打印链表)