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