题解 | #顺时针打印矩阵#

顺时针打印矩阵

http://www.nowcoder.com/practice/9b4c81a02cd34f76be2659fa0d54342a

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
       int up=0;
       int left=0;
       int down=matrix.length-1;
       int right=matrix[0].length-1;
       ArrayList list = new ArrayList(){};
       while(true){
           for(int i = left;i<=right;i++){
               list.add(matrix[up][i]);
           }
           up++;
           if(up>down) break;
           for(int i=up;i<=down;i++){
               list.add(matrix[i][right]);
           }
           right--;
           if(right<left) break;
           for(int i=right;i>=left;i--){
               list.add(matrix[down][i]);
           }
           down--;
           if(up>down) break;
           for(int i=down;i>=up;i--){
               list.add(matrix[i][left]);
           }
           left++;
           if(right<left) break;
       }
        return list;
    }
}
全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务