【陪伴式刷题】Day 8|字符串| 59.螺旋矩阵 II (spiral Matrix II)

刷题顺序按照代码随想录建议

题目描述

英文版描述

Given a positive integer n, generate an n x n matrix filled with elements from 1 to n(2) in spiral order.

Example 1:

Input: n = 3

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

Example 2:

Input: n = 1

Output: [[1]]

提示:

  • 1 <= n <= 20

英文版地址

leetcode.com/problems/sp...

中文版描述

给你一个正整数 n ,生成一个包含 1n^2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix

示例 1:

输入: n = 3

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

示例 2:

输入: n = 1

输出: [[1]]

提示:

  • 1 <= n <= 20

中文版地址

leetcode.cn/problems/sp...

俺这版

java 复制代码
class Solution {
    public int[][] generateMatrix(int n) {
int[][] result = new int[n][n];
        int row; // 行
        int col; // 列
        // 起始点
        int start = 0;
        // 初始值
        int num = 1;
        // 循环次数
        int loop = 1;

        while (start <= (n - 1) / 2 + 1) {
            for (int i = start; i < (n - loop); i++) {
                row = start;
                col = i;
                result[row][col] = num;
                num++;
            }
            for (int i = start; i < (n - loop); i++) {
                row = i;
                col = (n - loop);
                result[row][col] = num;
                num++;
            }
            for (int i = (n - loop); i > start; i--) {
                row = (n - loop);
                col = i;
                result[row][col] = num;
                num++;
            }
            for (int i = (n - loop); i > start; i--) {
                row = i;
                col = start;
                result[row][col] = num;
                num++;
            }
            start++;
            loop++;
        }

        if (n % 2 == 1) {
            result[n/2][n/2] = num;
        }
        return result;
    }
}

复杂度分析

  • 时间复杂度:O(n^2)
  • 空间复杂度:O(1)
相关推荐
YuTaoShao1 天前
【LeetCode 每日一题】3000. 对角线最长的矩形的面积
算法·leetcode·职场和发展
四谎真好看1 天前
Java 黑马程序员学习笔记(进阶篇6)
java·笔记·学习·学习笔记
星梦清河1 天前
宋红康 JVM 笔记 Day17|垃圾回收器
java·jvm·笔记
yvya_1 天前
JVM介绍
java·开发语言·jvm
烟雨书信1 天前
LINUX中Docker Swarm的介绍和使用
java·linux·docker
今天秃头了吗??1 天前
【JAVA】网络编程
java·网络·网络编程·socket
煎饼皮皮侠1 天前
【图解】idea中快速查找maven冲突
java·maven·intellij-idea·冲突
科兴第一吴彦祖1 天前
在线会议系统是一个基于Vue3 + Spring Boot的现代化在线会议管理平台,集成了视频会议、实时聊天、AI智能助手等多项先进技术。
java·vue.js·人工智能·spring boot·推荐算法
工一木子1 天前
HashMap源码深度解析:从“图书馆“到“智能仓库“的进化史
java·源码·hashmap
愚润求学1 天前
【贪心算法】day8
c++·算法·leetcode·贪心算法