编程题02

输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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.
https://www.nowcoder.com/questionTerminal/9b4c81a02cd34f76be2659fa0d54342a

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
        ArrayList<Integer> arr=new ArrayList<Integer>();
       if(matrix.length==0){
           return arr;
       }
        int n=matrix.length;
        int m=matrix[0].length;
        if(m==0){
            return arr;
        }
        int Layer=(Math.min(m,n)-1)/2+1;
        for(int i=0;i<Layer;i++){
           for(int k=i;k<m-i;k++){//从左到右
               arr.add(matrix[i][k]);
           } 
           for(int j=i+1;j<n-i;j++){//从右上到右下
                arr.add(matrix[j][m-i-1]);
           }
           for(int k=m-i-2;(k>=i)&&(n-i-1!=i);k--){//从右至左
               arr.add(matrix[n-i-1][k]);
           } 
            for(int j=n-i-2;(j>i)&&(m-i-1!=i);j--){//从左下到左上
                arr.add(matrix[j][i]);
            }
        }
        return arr;
    }
}

猜你喜欢

转载自blog.csdn.net/qq_40163148/article/details/83005051
今日推荐