螺旋矩阵 II

题目描述:给你一个正整数 n ,生成一个包含 1 到 \(n^{2}\) 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。

示例说明请见LeetCode官网。

来源:力扣(LeetCode)

链接:https://leetcode-cn.com/problems/spiral-matrix-ii/

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解法一:数组遍历

首先,result为要生成的正方形矩阵即二维数组,对应声明一个同样大小的flag二维数组记录相应位置是否已经走过,count为已记录的元素数量,i和j记录当前位置的索引位置,i初始化为0,j初始化为-1,然后按照向右、向下、向左、向右的顺序开始处理二维数组:

  • 向右:将j往右移动一位,判断是否没有超过n的界限并且移动后的位置是否没有遍历过并且count小于n*n,如果符合条件,则将count加1然后填充到当前(i, j)位置上,并且将该位置的标记位置为true,直到往右移不动为止;
  • 向下:将i往下移动一位,判断是否没有超过n的界限并且移动后的位置是否没有遍历过并且count小于n*n,如果符合条件,则将count加1然后填充到当前(i, j)位置上,并且将该位置的标记位置为true,直到往下移不动为止;
  • 往左:将j往左移动一位,判断是否不小于0并且移动后的位置是否没有遍历过并且count小于n*n,如果符合条件,则将count加1然后填充到当前(i, j)位置上,并且将该位置的标记位置为true,直到往左移不动为止;
  • 往上:将i往上移动一位,判断是否不小于0并且移动后的位置是否没有遍历过并且count小于n*n,如果符合条件,则将count加1然后填充到当前(i, j)位置上,并且将该位置的标记位置为true,直到往上移不动为止。

重复上面的过程,知道count等于n*n即所有的数字都填充到result中,最后返回result。

说明:和题目 LeetCode-054-螺旋矩阵 解法类似。

public class LeetCode_059 {
public static int[][] generateMatrix(int n) {
int[][] result = new int[n][n];
boolean[][] flag = new boolean[n][n];
int i = 0, j = -1, count = 0;
while (count < n * n) {
// 向右
while (j + 1 < n && !flag[i][j + 1] && count < n * n) {
j = j + 1;
count++;
result[i][j] = count;
flag[i][j] = true;
} // 向下
while (i + 1 < n && !flag[i + 1][j] && count < n * n) {
i = i + 1;
count++;
result[i][j] = count;
flag[i][j] = true;
} // 向左
while (j - 1 >= 0 && !flag[i][j - 1] && count < n * n) {
j = j - 1;
count++;
result[i][j] = count;
flag[i][j] = true;
} // 向上
while (i - 1 >= 0 && !flag[i - 1][j] && count < n * n) {
i = i - 1;
count++;
result[i][j] = count;
flag[i][j] = true;
}
}
return result;
} public static void main(String[] args) {
for (int[] ints : generateMatrix(4)) {
for (int anInt : ints) {
System.out.print(anInt + "\t");
}
System.out.println();
}
}
}

【每日寄语】 要永远面朝阳光生活,这样的话,那些不好的阴影就会被甩到后面。

LeetCode-059-螺旋矩阵 II的更多相关文章

  1. Java实现 LeetCode 59 螺旋矩阵 II

    59. 螺旋矩阵 II 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ...

  2. LeetCode 59. 螺旋矩阵 II(Spiral Matrix II)

    题目描述 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7 ...

  3. 【LeetCode】59.螺旋矩阵II

    59.螺旋矩阵II 知识点:数组: 题目描述 给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix . 示例 输入:n = 3 ...

  4. leetcode 54. 螺旋矩阵 及 59. 螺旋矩阵 II

    54. 螺旋矩阵 问题描述 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], [ 4, 5, ...

  5. 【LeetCode-面试算法经典-Java实现】【059-Spiral Matrix II(螺旋矩阵II)】

    [059-Spiral Matrix II(螺旋矩阵II)] [LeetCode-面试算法经典-Java实现][全部题目文件夹索引] 原题 Given an integer n, generate a ...

  6. LintCode-381.螺旋矩阵 II

    螺旋矩阵 II 给你一个数n生成一个包含1-n^2的螺旋形矩阵 样例 n = 3 矩阵为 [     [ 1, 2, 3 ],     [ 8, 9, 4 ],     [ 7, 6, 5 ] ] 标 ...

  7. LeetCode:螺旋矩阵||【59】

    LeetCode:螺旋矩阵||[59] 题目描述 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ...

  8. LeetCode:螺旋矩阵【54】

    LeetCode:螺旋矩阵[54] 题目描述 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 示例 1: 输入: [ [ 1, 2, 3 ], ...

  9. [LeetCode] 59. Spiral Matrix II 螺旋矩阵 II

    Given an integer n, generate a square matrix filled with elements from 1 to n^2 in spiral order. For ...

  10. LeetCode(59):螺旋矩阵 II

    Medium! 题目描述: 给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 示例: 输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, ...

随机推荐

  1. Django ORM 多对多操作 使用聚合函数和分组 F查询与Q查询

    创建表 # models.py form django.db import models class Book(models.Model): # 表名book,django会自动使用项目名+我们定义的 ...

  2. JDBC 操作预编译语句中LIKE模糊匹配怎么用

    问题描述 在使用JDBC 预编译执行语句时,遇到一个问题,那就是在含有LIKE的查询语句时,我到底怎么使用匹配符%._呢. 如: SELECT * FROM "+LQ_USERS+" ...

  3. Android动态加载布局之LayoutInflater【转】

    万分感谢大佬:https://www.jianshu.com/p/6a235ba5ee17 深入了解View<一>之Android LayoutInfalter原理分析 下文为:Layou ...

  4. laravel操作Redis排序/删除/列表/随机/Hash/集合等方法全解

    Song • 3563 次浏览 • 0 个回复 • 2017年10月简介 Redis模块负责与Redis数据库交互,并提供Redis的相关API支持: Redis模块提供redis与redis.con ...

  5. 7月3日下午 微擎芸众商城 设计思路 - laravel路由底层源码解读

    学习参考文章 https://learnku.com/articles/13622/the-principle-of-laravel-routing-execution <?phpnamespa ...

  6. SEL类型

    1.什么是SEL类型 SEL类型代表着方法的签名,在类对象的方法列表中存储着该签名与方法代码的对应关系 每个类的方法列表都存储在类对象中 每个方法都有一个与之对应的SEL类型的对象 根据一个SEL对象 ...

  7. 解析视频真实地址播放 By HL

    手思3.0启动,从手思1.0版的iOS2个人,到现在的N个人,如今又回来做手思了. 重新做自然就要比之前的更好,更强大,而视频播放页的效果相当的不乐观. 公司用的是优酷的视频连接,只能用webview ...

  8. Oracle 撤回已经提交的事务

    在PL/SQL操作了一条delete语句习惯性的commit 了,因少加了where条件 导致多删了数据 1.查询视图v$sqlarea,找到操作那条SQL的时间(FIRST_LOAD_TIME) s ...

  9. Solution -「BZOJ #3786」星系探索

    \(\mathcal{Description}\)   Link.   给定一棵含 \(n\) 个点的有根树,点有点权,支持 \(q\) 次操作: 询问 \(u\) 到根的点权和: 修改 \(u\) ...

  10. Winds10 安装JDK8.0教程

    首先下载一个jdk,可以通过这个链接下载:https://pan.baidu.com/s/1aP6SdL8UQK_C2GvALLb6Wg也可以去官网下载:https://www.oracle.com/ ...