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

顺时针打印矩阵

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

    public ArrayList<Integer> printMatrix(int [][] matrix) {

        if (matrix == null || matrix.length == 0){
            return new ArrayList<>();
        }

        int up = 0;
        int right = matrix[0].length - 1;
        int down = matrix.length - 1;
        int left = 0;

        ArrayList<Integer> res = new ArrayList<>();

        while (left <= right && up <= down){

            for (int i = left; i <= right; i++) {

                res.add(matrix[up][i]);
            }

            for (int i = up + 1; i <= down; i++) {

                res.add(matrix[i][right]);
            }

            for (int i = right - 1; i >= left && left < right && down > up; i--) {

                res.add(matrix[down][i]);
            }

            for (int i = down - 1; i > up && down > up && left < right; i--) {

                res.add(matrix[i][left]);
            }

            up ++;
            right --;
            down --;
            left ++;
        }


        return res;
    }
全部评论

相关推荐

刘湘_passion:太强了牛肉哥有被激励到
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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