剑指offer19题

import java.util.ArrayList;
/**
 * 输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,
 * 例如,如果输入如下4 X 4矩阵: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
 * 则依次打印出数字1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10.
 * <p>
 * 思路:
 * 1、打印一层
 * 2、递归
 */
public class Solution19 {
    public ArrayList<Integer> printMatrix(int[][] array) {
        ArrayList<Integer> result = new ArrayList<Integer>();
        if (array.length == 0) {
            return result;
        }
        int n = array.length, m = array[0].length;
        if (m == 0) {
            return result;
        }
        //这个是层数
        int layers = (Math.min(n, m) - 1) / 2 + 1;
        for (int i = 0; i < layers; i++) {
            for (int k = i; k < m - i; k++) {
                //左至右
                result.add(array[i][k]);
            }
            for (int j = i + 1; j < n - i; j++) {
                //右上至右下
                result.add(array[j][m - i - 1]);
            }
            for (int k = m - i - 2; (k >= i) && (n - i - 1 != i); k--) {
                //右至左
                result.add(array[n - i - 1][k]);
            }
            for (int j = n - i - 2; (j > i) && (m - i - 1 != i); j--) {
                //左下至左上
                result.add(array[j][i]);
            }
        }
        return result;
    }
}

 

posted @ 2020-08-09 20:48  Adom_ye  阅读(114)  评论(0编辑  收藏  举报