LeetCode-数组下标的使用

26. Remove Duplicates from Sorted Array 从已排序的数组中移除重复元素

https://leetcode.com/problems/remove-duplicates-from-sorted-array/

题目:给定已排序数组nums,移除重复项,使每个元素只出现一次,并返回新的长度。

思路:使用快慢指针来记录每次遍历的索引,最开始时两个指针都指向第一个数字,如果两个指针指的数字相同,则快指针向前走一步,如果不同,则两个指针都向前走一步。这样当快指针走完整个数组后,慢指针当前的索引加1就是数组中不同数字的个数。

31. Next Permutation 下一个排列

https://leetcode.com/problems/next-permutation/

题目:实现下一个排列,它将数字重新排列成词汇学上的下一个更大的数字排列。如果这样的安排是不可能的,它必须将其重新排列为最低可能的顺序(即,按升序排序)。

思路:需要找到给定数字之后的下一个最大数。从后往前找到第一个下降的数字,以升序方式交换下降部分。

36. Valid Sudoku 有效的数独

https://leetcode.com/problems/valid-sudoku/

题目:确定9x9 Sudoku板是否有效。每一行必须包含数字1-9,不重复;每一列必须包含数字1-9,不重复;大网格的每个3x3小网格必须包含数字1-9,不重复。

思路:在遍历每个数字的时候,就看看包含当前位置的行和列以及 3x3 小方阵中是否已经出现该数字,这里需要三个 boolean 型矩阵,大小跟原数组相同,分别记录各行,各列,各小方阵是否出现某个数字,其中行和列标志下标很好对应,就是小方阵的下标需要稍稍转换一下,

75. Sort Colors 颜色排序

https://leetcode.com/problems/sort-colors/

题目:给定n个对象为红色、白色或蓝色的数组,将它们按位置排序,以便相同颜色的对象相邻,颜色按红色、白色和蓝色的顺序排列。在这里,我们将使用整数0、1和2分别表示红色、白色和蓝色。

思路:①2-pass:最容易想到的方法就是遍历数组,记录下0、1和2的个数,然后根据0的个数重写该数组,接着根据1的个数,最后根据2的个数。

   ②1-pass:遍历数组,将遇到的0放到数组前面,遇到的2放到数组后面,需要设置p1、p2分别指向数组头和尾来进行操作。

79. Word Search 找单词

https://leetcode.com/problems/word-search/

题目:给定一个2D板(二维数组)和一个单词,查找该单词是否存在于网格中。单词可以由顺序相邻单元的字母构成,其中“相邻”单元是水平或垂直相邻的单元。同一字母不得使用超过一次。

思路:深度优先遍历DFS,遍历二维数组,每一个点都作为起点来匹配给定字符串,并用大小同为m x n的二维数组visited来记录该点是否被访问过,对于被访问过的点则直接返回false。需要将两个二维数组、起始坐标、当前字符串索引以及字符串传入到递归函数。如果二维数组当前字符与字符串当前索引对应的字符匹配,则对当前索引的四个方向分别应用递归函数,如果有一个true返回,则表示可以找到,否则不能。

80. Remove Duplicates from Sorted Array II 移除有序数组中的重复项 II

ohttps://leetcode.com/problems/remove-duplicates-from-sorted-array-ii/

题目:给定有序数组nums,移除重复项,使重复最多出现两次,并返回新的长度。

思路:使用count来记录还允许重复几次,count初始化为1,如果重复一次,则count减1。再出现重复时,快指针前进一步,如果遇到的不是重复的数,则重新设置count为1。

猜你喜欢

转载自www.cnblogs.com/nomad1c/p/11368210.html
今日推荐