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

顺时针打印矩阵

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

直接找规律,计算下标
import java.util.*;
import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
        //第一次m个,第二次n-1个,第三次m-1个,第四次n-2,第五次m-2个,第六次n-3个,第七次m-3......
        //第i次和第i+4次遍历方向相同。
        ArrayList<Integer> arr = new ArrayList<>();
        int n = matrix.length;
        int m = matrix[0].length;
        int times = (n < m) ? 2 * n - 1 : 2 * m;
        for (int i = 1; i <= times; i++) {
            if (i % 4 == 1) for (int j = 0; j < m - i / 2; j++) arr.add(matrix[i / 4][i / 4 + j]);
            else if (i % 4 == 2) for (int j = 0; j < n - i / 2; j++) arr.add(matrix[j + i / 4 + 1][m - i / 4 - 1]);
            else if (i % 4 == 3) for (int j = 0; j < m - i / 2; j++) arr.add(matrix[n - 1 - i / 4][m - 2 - i / 4 - j]);
            else if (i % 4 == 0) for (int j = 0; j < n - i / 2; j++) arr.add(matrix[n - 1 - i / 4 - j][i / 4 - 1]);
        }
        return arr;
    }
}


全部评论

相关推荐

我即大橘:耐泡王
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
昨天 10:48
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务