题目描述:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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 [][] matrix) {
int row = matrix.length,col=matrix[0].length;
ArrayList<Integer> list = new ArrayList<Integer>();
int left = 0,right=col,up=0,bottom=row;
while(up<bottom&&left<right){
for(int i=left;i<right;i++){
list.add(matrix[up][i]);
}
for(int i=up+1;i<bottom;i++){
list.add(matrix[i][right-1]);
}
for(int i=right-2;i>=left&&bottom-1!=up;i--){
list.add(matrix[bottom-1][i]);
}
for(int i=bottom-2;i>up&&right-1!=left;i--){
list.add(matrix[i][left]);
}
up++;
left++;
right--;
bottom--;
}
return list;
}
}