劍指offer---順時針打印矩陣(Java)

題目描述

輸入一個矩陣,按照從外向裏以順時針的順序依次打印出每一個數字,例如,如果輸入如下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.

解析思路

在這裏插入圖片描述

實現代碼

import java.util.ArrayList;


public class Solution {
    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(m,n)-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;       
    }
}

實現效果

在這裏插入圖片描述

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章