IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Leetcode-数组操作 -> 正文阅读

[数据结构与算法]Leetcode-数组操作


q54 螺旋矩阵


题目传送门


题解

在这里插入图片描述

以一层层的方式去遍历每一行和每一列,每一行或者每一列的最后一个元素就是下一列或者下一行的开始。因为题目中的矩阵边长不一定相等,所以最后会多出来一行或者一列,另外处理即可。

func spiralOrder(matrix [][]int) []int {
	if len(matrix) == 0 {
		return []int{}
	}
	res := make([]int, 0)
	top, bottom, left, right := 0, len(matrix) - 1, 0, len(matrix[0]) - 1
	// 以环的方式遍历,每行或者列的最后一个元素就是后一列或者行的开始
	for top < bottom && left < right {
		for i := left; i < right; i++ {
			res = append(res, matrix[top][i])
		}
		for i := top; i < bottom; i++ {
			res = append(res, matrix[i][right])
		}
		for i := right; i > left; i-- {
			res = append(res, matrix[bottom][i])
		}
		for i := bottom; i > top; i-- {
			res = append(res, matrix[i][left])
		}
		right--
		top++
		bottom--
		left++
	}
	// 多出一行
	if top == bottom {
		for i := left; i <= right; i++ {
			res = append(res, matrix[top][i])
		}
	// 多出一列
	} else if left == right {
		for i := top; i <= bottom; i++ {
			res = append(res, matrix[i][left])
		}
	}
	return res
}

q73 矩阵置零


题目传送门


题解

用一个哈希表来标记值为0的坐标,然后遍历哈希表,将同行和同列的元素置为0 。

type Point struct {
	x int
	y int
}

func setZeroes(matrix [][]int)  {
	m, n := len(matrix), len(matrix[0])
	hashTable := make(map[Point]bool)
	for i := 0; i < m; i++ {
		for j := 0; j < n; j++ {
			if matrix[i][j] == 0 && hashTable[Point{i, j}] == false {
				hashTable[Point{i, j}] = true
			}
		}
	}
	for key, _ := range hashTable {
		// 同列变为0
		for i := 0; i < m; i++ {
			matrix[i][key.y] = 0
		}
		// 同行变为0
		for i := 0; i < n; i++ {
			matrix[key.x][i] = 0
		}
	}
}

q78 子集


题目传送门


题解

该题可以使用dfs和bfs两种方法来解决。

dfs:

func subsets(nums []int) [][]int {
	res = make([][]int, 0)
	dfs(nums, 0, nil)
	return res
}

func dfs(nums []int, path int, prefix []int)  {
	if path >= len(nums) {
		dst := make([]int, len(prefix))
		copy(dst, prefix)
		res = append(res, dst)
		return
	}
	dfs(nums, path + 1, append(prefix, nums[path]))
	dfs(nums, path + 1, prefix)
}

bfs:

func subsets1(nums []int) [][]int {
	res := make([][]int, 0)
	path := make([]int, 0)
	var bfs func(int)
	bfs = func(start int) {
		if start > len(nums) {
			return
		}
		tmp := make([]int, len(path))
		copy(tmp, path)
		res = append(res, tmp)
		for i := start; i < len(nums); i++ {
			path = append(path, nums[i])
			bfs(i + 1)
			path = path[:len(path) - 1]
		}
	}
	bfs(0)
	return res
}

q384 打乱数组


题目传送门


题解

这道题最难的部分就是怎么去打乱数组,策略是这样的:循环n次,每次将随机获得的数组元素与数组的最后一个元素交换。

type Solution struct {
	nums []int
	reNums []int
}

func Constructor(nums []int) Solution {
	return Solution{nums: nums, reNums: append([]int{}, nums...)}
}

func (this *Solution) Reset() []int {
	return this.reNums
}

func (this *Solution) Shuffle() []int {
	for n := len(this.nums); n > 0; n-- {
		randIndex := rand2.Intn(n)
		this.nums[n - 1], this.nums[randIndex] = this.nums[randIndex], this.nums[n - 1]
	}
	return this.nums
}

q581 最短连续无序子数组


题目传送门


题解

首先要确定子数组的边界,我们设为begin和end。其实begin的就是比最小值大的最后一个数的下标,而end实际上就是比最大值小的最后一个元素的下标。举个例子就很好理解:{1, 2, 5, 4, 3, 6, 7} , 在这个例子中,比最大值小的最后一个数字其实是3,因为数组遍历到3的时候,此时的最大值是5,所以3是最后一个比最大值小的数,在后面的遍历中,都是更新最大值。那么找左边界也是一样的道理。

func findUnsortedSubarray(nums []int) int {
	n := len(nums)
	min, max := nums[n - 1], nums[0]
	begin, end := -1, -1
	for i := 0; i < n; i++ {
		if nums[i] >= max {
			max = nums[i]
		} else {
			end = i
		}
		if nums[n - i - 1] <= min {
			min = nums[n - i - 1]
		} else {
			begin = n - i - 1
		}
	}
	// 特判
	if end == -1 {
		return 0
	}
	return end - begin + 1
}

q945 使用数组唯一的最小增量


题目传送门


题解

首先将数组排序,然后遍历数组,如果当前元素小于等于它前一个元素,那么就将它变为前面一个数+1 。

func minIncrementForUnique(nums []int) int {
	sort.Ints(nums)
	move := 0
	for i := 1; i < len(nums); i++ {
		if nums[i] <= nums[i - 1] {
			prev := nums[i]
			nums[i] = nums[i - 1] + 1
			move += nums[i] - prev
		}
	}
	return move
}

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-29 23:20:21  更:2022-01-29 23:21:52 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 15:53:37-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码