顺时针打印矩阵

顺时针打印矩阵

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

顺时针打印矩阵

思路:利用四个边界来控制

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

相关推荐

11-15 19:28
已编辑
蚌埠坦克学院 硬件开发
点赞 评论 收藏
分享
粗心的雪碧不放弃:纯学历问题,我这几个月也是一直优化自己的简历,后来发现优化到我自己都觉得牛逼的时候,发现面试数量也没有提升,真就纯学历问题
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务