劍指 Offer 17 – 列印從1到最大的n位數
題目:
輸入數字 n,按順序列印出從 1 到最大的 n 位十進制數。比如輸入 3,則列印出 1、2、3 一直到最大的 3 位數 999。
示例 1:
輸入: n = 1
輸出: [1,2,3,4,5,6,7,8,9]
說明:
- 用傳回一個整數清單來代替列印
- n 為正整數
代碼:
package com.xujinshan.offer.offer17;
import java.util.Arrays;
/**
* @Author: xu[email protected]
* 劍指 Offer 17 -- 列印從1到最大的n位數
* 輸入數字 n,按順序列印出從 1 到最大的 n 位十進制數。比如輸入 3,
* 則列印出 1、2、3 一直到最大的 3 位數 999。
* <p>
* 示例 1:
* <p>
* 輸入: n = 1
* 輸出: [1,2,3,4,5,6,7,8,9]
* <p>
* 說明:
* <p>
* 用傳回一個整數清單來代替列印
* n 為正整數
*/
class Solution {
public int[] printNumbers(int n) {
int result = 1;
for (int i = 0; i < n; i++) {
result *= 10;
}
int[] res = new int[result - 1];
for (int i = 0; i < result - 1; i++) {
res[i] = i + 1;
}
return res;
}
}
public class Offer17 {
public static void main(String[] args) {
System.out.println(Arrays.toString(new Solution().printNumbers(1)));
}
}
結果:
