天天看點

劍指 Offer 17 -- 列印從1到最大的n位數劍指 Offer 17 – 列印從1到最大的n位數

劍指 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)));
    }
}
           

結果:

劍指 Offer 17 -- 列印從1到最大的n位數劍指 Offer 17 – 列印從1到最大的n位數