每日一题 --- 螺旋矩阵 II[力扣][Go]

螺旋矩阵 II

题目:59. 螺旋矩阵 II - 力扣(LeetCode)

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

示例 1:

复制代码
输入:n = 3
输出:[[1,2,3],[8,9,4],[7,6,5]]

示例 2:

复制代码
输入:n = 1
输出:[[1]]

提示:

  • 1 <= n <= 20

方法一:

先准备好一个n*n的数组,然后给据规则生成就行了(有的是按环数具体可看代码随想录,我这个是按方向一个个生成),一定要注意,代码如下

go 复制代码
var (
	Dir = [4][2]int{{0, 1}, {1, 0}, {0, -1}, {-1, 0}}
)

func generateMatrix(n int) [][]int {
	numss := make([][]int, n)
	for i := 0; i < n; i++ {
		numss[i] = make([]int, n)
	}
	count := 1
	// 从 [1][n-1]处开始
	x, y := 0, 0
	// guaiwan每循环两次就要再减一
	time := 1
	// 减过的次数
	subnum := 0
	guaiwan := n - subnum
	dir := 0
	for count <= n*n {
		numss[x][y] = count
		count++
		guaiwan--
		if guaiwan == 0 {
			dir++
			if dir == 4 {
				dir = 0
			}
			time--
			if time == 0 {
				time = 2
				subnum++
			}
			guaiwan = n - subnum
		}
		x = x + Dir[dir][0]
		y = y + Dir[dir][1]
	}
	return numss
}

虽然只用了一个for循环,但是时间复杂度为O(n²)。

而且用了很多控制方向的变量,空间复杂度较大(我希望有更好的解法)。

注意这种循环处理不好就会报错,在设置条件时一定要细心:

方法二:

如果您有更好的解法,别忘了@博主去学习啊,感谢了

相关推荐
05候补工程师20 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵
XMYX-020 小时前
33 - Go 文本模板 template:从入门到原理深挖
golang·正则表达式
青山师20 小时前
HashMap深度解析:哈希冲突、扩容机制与线程安全
算法·安全·哈希算法·java面试·hashmap源码
货拉拉技术20 小时前
私域转化率翻倍的秘密:我们把多模态Agent融进了私域营销
人工智能·算法·设计模式
WL_Aurora20 小时前
备战蓝桥杯国赛【Day 17】
算法·蓝桥杯
kcuwu.20 小时前
决策树与集成学习深度解析:从原理到实践
算法·决策树·集成学习
programhelp_21 小时前
2026 Fall Coinbase Software Engineer OA 真题分享与通关指南
算法
CQU_JIAKE21 小时前
5.19【A】
算法
数智工坊21 小时前
【FDA论文阅读】: 傅里叶域自适应——零训练成本的语义分割无监督域适配方法
论文阅读·人工智能·学习·算法·自动驾驶
承渊政道21 小时前
【贪心算法】(经典实战应用解析(五):单调递增的数字、坏了的计算器、合并区间、⽆重叠区间、⽤最少数量的箭引爆⽓球)
数据结构·c++·leetcode·贪心算法·排序算法·动态规划·哈希算法