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

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

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

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

 

转载于:https://www.cnblogs.com/nomad1c/p/11368210.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 题目描述:给定一个升序整型数组和一个目标值,搜索数组是否存在目标值,若存在返回下标,否则返回-1。 解题思路:由于数组是有序的,可以使用二分查找的方法进行搜索。首先确定数组的左右边界,然后计算间位置的下标,比较间位置的值和目标值的大小,如果相等则返回下标,如果间位置的值大于目标值,则在左半部分继续查找,否则在右半部分继续查找,直到找到目标值或者左右边界相遇。 代码实现: class Solution { public: int search(vector<int>& nums, int target) { int left = , right = nums.size() - 1; while (left <= right) { int mid = left + (right - left) / 2; if (nums[mid] == target) { return mid; } else if (nums[mid] > target) { right = mid - 1; } else { left = mid + 1; } } return -1; } }; ### 回答2: 二分查找(Binary Search)是一种优秀的查找算法,其时间复杂度为O(logn)。在查找有序数组时,二分查找是一种非常高效的方法。 通过不断地将区间缩小为一半来进行查找,二分查找是一种分治思想的应用。具体来说,对于给定的有序数组nums,在区间[0, n-1]查找某一元素target。每次找到区间的间值mid,将mid与target进行比较,如果mid等于target,返回mid的下标。否则,如果mid大于target,在左侧区间[0, mid-1]继续查找;如果mid小于target,在右侧区间[mid+1, n-1]继续查找。如此迭代直至找到target或者区间被缩小为空。 以下是二分查找的简单实现,其left和right表示当前查找区间的左右边界。 ``` int binarySearch(vector<int>& nums, int target) { int n = nums.size(); int left = 0, right = n - 1; while (left <= right) { int mid = left + (right - left) / 2; if (nums[mid] == target) return mid; else if (nums[mid] > target) right = mid - 1; else left = mid + 1; } return -1; } ``` 需要注意的是,该算法要求目标数组必须有序,否则不能保证正确性。另外,在实现时需要注意整型溢出问题,可以使用left + (right - left) / 2来防止溢出。 ### 回答3: 题目描述: 给定一个n个元素有序的(升序)整型数组nums和一个目标值target,写一个函数搜索nums的target,如果目标值存在返回下标,否则返回-1。 解题思路: 由于数组有序,可以考虑使用二分查找的方法。二分查找的基本思想是将有序数组一分为二,确认目标值在哪个子数组,然后继续对子数组进行二分查找。具体实现则是定义一个左指针和一个右指针,不断将数组分成两个子数组,然后判断目标值在哪个子数组,直到左右指针相遇时结束。 代码实现: class Solution { public: int search(vector<int>& nums, int target) { int left = 0; int right = nums.size() - 1; while (left <= right) { int mid = (left + right) / 2; if (nums[mid] == target) { return mid; } else if (nums[mid] < target) { left = mid + 1; } else { right = mid - 1; } } return -1; } }; 时间复杂度分析: 二分查找的时间复杂度为O(log n),其n为数组长度。因为每次都将数组分成两个子数组,所以可以得到一个递归式:T(n) = T(n/2) + O(1),根据主定理可以得到其时间复杂度为O(log n)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值