题解 | #螺旋矩阵#

螺旋矩阵

http://www.nowcoder.com/practice/7edf70f2d29c4b599693dc3aaeea1d31

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> spiralOrder(int[][] matrix) {
        int m = matrix.length;
        ArrayList<Integer> arrayList = new ArrayList<>();
        
        if (0 == m) {
            return arrayList;
        }
        if (1 == m) {
            for (int i : matrix[0]) {
                arrayList.add(i);
            }
            return arrayList;
        }
        
        int n = matrix[0].length;
        if (1 == n) {
            for (int i = 0; i < m; i++) {
                arrayList.add(matrix[i][0]);
            }
            return arrayList;
        }
        
        int startRow = 0;
        int endRow = m - 1;
        int startColumn = 0;
        int endColumn = n - 1;
        
        while (arrayList.size() < m * n) {
            for (int i = startColumn; i <= endColumn; i++) {
                arrayList.add(matrix[startRow][i]);
            }
            startRow++;
            if (arrayList.size() == m * n) {
                break;
            }
            for (int i = startRow; i <= endRow; i++) {
                arrayList.add(matrix[i][endColumn]);
            }
            endColumn--;
            if (arrayList.size() == m * n) {
                break;
            }
            for (int i = endColumn; i >= startColumn; i--) {
                arrayList.add(matrix[endRow][i]);
            }
            endRow--;
            if (arrayList.size() == m * n) {
                break;
            }
            for (int i = endRow; i >= startRow; i--) {
                arrayList.add(matrix[i][startColumn]);
            }
            startColumn++;
        }
        return arrayList;
    }
}
全部评论

相关推荐

10-24 11:10
山西大学 Java
若梦难了:哥们,面试挂是很正常的。我大中厂终面挂,加起来快10次了,继续努力吧。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务