剑指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;       
    }
}

实现效果

在这里插入图片描述

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