螺旋矩阵 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. 字体替换 re.sub

    dic={'hqo3r': '迎', 'hq6ic': '名', 'hq7yw': '头', 'hq1lk': '新', 'hqpe1': '肇'} content=''' 总体hqo3r则,错的注( ...

  2. PostgreSQL逻辑订阅

    测试环境:PostgreSQL 13.2 1.逻辑订阅简介 由于物理复制只能做到这个集群的复制,不能正对某个对象(表)进行复制,且物理复制的备库只能读,不能写.相反,逻辑订阅同时支持主备库读写,且可以 ...

  3. 尚硅谷全套课件整理:Java、前端、大数据、安卓、面试题

    目录 Java 尚硅谷 IT 精英计划 JavaSE 内部学习笔记.pdf 尚硅谷 Java 基础实战之银行项目.pdf 尚硅谷 Java 技术之 JDBC.pdf 尚硅谷 Java 技术之 Java ...

  4. mysql连接出错:ERROR 1040 (HY000): Too many connections

    1.查看mysql的最大连接数:show variables like '%max_connections%';  2. 查看服务器响应的最大连接数: 3. 设置最大连接数: set GLOBAL m ...

  5. IM开发通信协议基础知识(一)---TCP、UDP、HTTP、SOCKET

    感谢大佬:https://www.cnblogs.com/sixindev/p/4723590.html 下面这些内容不了解也可以进行开发,深入了解一下还是收益良多 区别 TCP.UDP.HTTP.S ...

  6. Apache Http Server与Tomcat6 的负载均衡(二)

    一般来说,实现Apache与Tomcat6的负载均衡有两种方式,一种是使用mod_jk,另一种是使用mod_proxy模块.本文只讨论mod_jk方式. 无论使用哪种方式,一般都要经过以下这几个步骤( ...

  7. 谷粒商城Day1

    环境搭建 安装JDK1.8: 1 下载并解压jdk1.8 tar -zxvf jdk-8u281-linux-x64.tar.gz(检查本机有没有jdk有的话卸载掉.安装上自己的jdk) 2 配上环境 ...

  8. netty系列之:JVM中的Reference count原来netty中也有

    目录 简介 ByteBuf和ReferenceCounted ByteBuf的基本使用 ByteBuf的回收 ByteBuf的衍生方法 ChannelHandler中的引用计数 内存泄露 总结 简介 ...

  9. Solution -「Gym 102956F」Find the XOR

    \(\mathcal{Description}\)   Link.   给定 \(n\) 个点 \(m\) 条边的连通无向图 \(G\),边有边权.其中 \(u,v\) 的距离 \(d(u,v)\) ...

  10. Solution -「LOJ #6053」简单的函数

    \(\mathcal{Description}\)   Link.   积性函数 \(f\) 满足 \(f(p^c)=p\oplus c~(p\in\mathbb P,c\in\mathbb N_+) ...