54.螺旋矩阵

54.螺旋矩阵

思路:算技巧吧 需记忆

1.设定上下左右边界
2.其次向右移动到最右,此时第一行因为已经使用过了,可以将其从图中删去,体现在代码中就是重新定义上边界
3.判断若重新定义后,上下边界交错,表明螺旋矩阵遍历结束,跳出循环,返回答案
4.若上下边界不交错,则遍历还未结束,接着向下向左向上移动,操作过程与第一,二步同理
5.不断循环以上步骤,直到某两条边界交错,跳出循环,返回答案

class Solution {
public:
    vector<int> spiralOrder(vector<vector<int>>& matrix) {
        vector<int>res;
        int up=0;
        int down=matrix.size() - 1;
        int left = 0;
        int right = matrix[0].size() - 1;
        while(true){
            for(int i=left;i<=right;i++){//第一行从左往右
                res.push_back(matrix[up][i]);
            }
            up++;//更新上边界
            if(up>down) break; //上下边界相交,结束
            for(int i=up;i<=down;i++){//最后一列从上往下
                res.push_back(matrix[i][right]);
            }
            right--;//更新右边界
            if(right<left) break;
            for(int i=right;i>=left;i--){
                res.push_back(matrix[down][i]);
            }
            down--;
            if(down<up) break;
            for(int i=down;i>=up;i--){
                res.push_back(matrix[i][left]);
            }
            left++;
            if(left>right)  break;
        }
        return res;
    }
};
### Java 实现螺旋矩阵 为了实现一个能够按照顺时针方向遍历并打印出矩形数组中所有元素的功能,在Java中有多种方法可以达成这一目标。下面提供了一种基于边界控制的方法来完成此操作[^1]。 #### 方法概述 该方法通过定义四个变量分别表示当前处理区域的上界、下界、左界以及右界,随着每一圈数据读取完毕后调整这些边界的数值从而缩小包围范围直至整个矩阵被完全访问过为止。 #### 示例代码 以下是具体的Java程序示例: ```java public class SpiralMatrix { public static List<Integer> spiralOrder(int[][] matrix) { List<Integer> result = new ArrayList<>(); if (matrix.length == 0 || matrix[0].length == 0){ return result; } int top = 0; // 上边界 int bottom = matrix.length - 1; // 下边界 int left = 0; // 左边界 int right = matrix[0].length - 1; // 右边界 while(true){ for(int i=left;i<=right;i++)// 向右移动直到最右边 result.add(matrix[top][i]); if(++top > bottom) break; for(int i=top;i<=bottom;i++)// 向下移动直到最底端 result.add(matrix[i][right]); if(--right < left) break; for(int i=right;i>=left;i--)// 向左移动直到最左边 result.add(matrix[bottom][i]); if (--bottom < top) break; for(int i=bottom;i>=top;i--)// 向上移动到起始位置上方一格 result.add(matrix[i][left]); if (++left > right) break; } return result; } } ``` 这段代码实现了对于任意大小(`m×n`)输入矩阵的顺时针顺序遍历,并将结果存储在一个列表当中返回给调用者[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值