顺时针打印矩阵(剑指offer_29)

Posted ziytong

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了顺时针打印矩阵(剑指offer_29)相关的知识,希望对你有一定的参考价值。

题目描述


下图的矩阵顺时针打印结果为: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) {
        ArrayList<Integer>  ret = new ArrayList<>();
        int r1 = 0, r2 = matrix.length - 1, c1 = 0, c2 = matrix[0].length - 1;
        while(r1 <= r2 && c1 <= c2)
        {
            for(int i = c1; i <= c2; i++)
                ret.add(matrix[r1][i]);
            for(int i = r1+1; i <= r2; i++)   //注意边界条件1
                ret.add(matrix[i][c2]);
            if(r1 != r2) 
                for(int i = c2-1; i >= c1; i--) //注意边界条件2
                    ret.add(matrix[r2][i]);
            if(c1 != c2)
                for(int i = r2-1; i > r1; i--)  //注意边界条件3
                    ret.add(matrix[i][c1]);
            r1++;r2--;c1++;c2--;
        }
        return ret;
    }
}

以上是关于顺时针打印矩阵(剑指offer_29)的主要内容,如果未能解决你的问题,请参考以下文章

剑指 Offer 29. 顺时针打印矩阵 的 详细题解

剑指offer面试题 29. 顺时针打印矩阵

剑指offer面试题 29. 顺时针打印矩阵

Java 剑指offer(29) 顺时针打印矩阵

完整可运行代码剑指 Offer 29. 顺时针打印矩阵

完整可运行代码剑指 Offer 29. 顺时针打印矩阵