54. 螺旋矩阵【rust题解】

题目

给你一个 m 行 n 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。

示例

示例 1

image.png

输入:matrix = [[1,2,3],[4,5,6],[7,8,9]]

输出:[1,2,3,6,9,8,7,4,5]

示例 2

image.png

输入:matrix = [[1,2,3,4],[5,6,7,8],[9,10,11,12]]

输出:[1,2,3,4,8,12,11,10,9,5,6,7]

提示

m == matrix.length
n == matrix[i].length
1 <= m, n <= 10
-100 <= matrix[i][j] <= 100

思路

深搜,方向旋转。需要特别处理在最左边往上搜索的情况。

AC代码

impl Solution {
    pub fn dfs(v: &Vec<Vec<i32>>, vis: &mut Vec<Vec<bool>>, x: i32, y: i32) -> Vec<i32> {
        let x_len = v.len() as i32;
        let y_len = v[0].len() as i32;
        let mut res: Vec<i32> = Vec::new();
        if x < 0 || x >= x_len || y < 0 || y >= y_len || vis[x as usize][y as usize] {
            return res;
        }
        vis[x as usize][y as usize] = true;
        let mut res1: Vec<i32> = Vec::new();
        let mut res2: Vec<i32> = Vec::new();
        let mut res3: Vec<i32> = Vec::new();
        let mut res4: Vec<i32> = Vec::new();
        res1 = match x >= 1 && (y == 0 || (y >= 1 && vis[x as usize][y as usize - 1])) && !vis[x as usize - 1][y as usize]{
            true => Solution::dfs(v, vis, x - 1, y),
            _ => Solution::dfs(v, vis, x, y + 1)
        };
        res2 = Solution::dfs(v, vis, x + 1, y);
        res3 = Solution::dfs(v, vis, x, y - 1);
        res4 = Solution::dfs(v, vis, x - 1, y);
        res.push(v[x as usize][y as usize]);
        res.extend(res1);
        res.extend(res2);
        res.extend(res3);
        res.extend(res4);
        res
    }

    pub fn spiral_order(v: Vec<Vec<i32>>) -> Vec<i32> {
        let x_len = v.len();
        let y_len = v[0].len();
        let mut vis: Vec<Vec<bool>> = vec![vec![false; y_len]; x_len];
        Solution::dfs(&v, &mut vis, 0 , 0)
    }
}

在这里插入图片描述

相关推荐

  1. LeetCode 54. 螺旋矩阵

    2024-06-07 07:38:03       38 阅读
  2. 54.螺旋矩阵

    2024-06-07 07:38:03       43 阅读
  3. 力扣54. 螺旋矩阵

    2024-06-07 07:38:03       68 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-07 07:38:03       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-07 07:38:03       100 阅读
  3. 在Django里面运行非项目文件

    2024-06-07 07:38:03       82 阅读
  4. Python语言-面向对象

    2024-06-07 07:38:03       91 阅读

热门阅读

  1. UDP声音传输:播放的声音有很大的噪音

    2024-06-07 07:38:03       32 阅读
  2. MySQL DBA项目实战系列培训课程【MySQL 8.4最新版】

    2024-06-07 07:38:03       26 阅读
  3. 使用docker安装mysql详细教程

    2024-06-07 07:38:03       30 阅读
  4. 数组知识点

    2024-06-07 07:38:03       33 阅读
  5. 天气数据集2-应用RNN做天气预测

    2024-06-07 07:38:03       23 阅读
  6. 数据结构:共享栈

    2024-06-07 07:38:03       27 阅读