博客主页:博主链接
本文由 M malloc 原创,首发于 CSDN
学习专栏推荐:LeetCode刷题集!
欢迎点赞 收藏 ⭐留言 如有错误敬请指正!
未来很长,值得我们全力奔赴更美好的生活✨
------------------❤️分割线❤️-------------------------
————————————————
大家好呀,今天给大家带来的是本周学习的LeetCode刷题,那么话不多说我们直接进入正题吧!
常见的双指针有两种,一种是对撞双指针,一种是左右指针。
对撞指针:一般用于顺序结构中,也称左右指针。
left == right(两个指针指向同一个位置)
left > rigth(两个指针错开)
快慢指针
这种方法针对处理环形链表或数组非常有用
快慢指针的实现方式
最常用的一种方式
1、题目链接:283.移动零
2、题目描述:
给定⼀个数组 nums ,编写⼀个函数将所有 0 移动到数组的末尾,同时保持⾮零元素的相对顺
序。
请注意 ,必须在不复制数组的情况下原地对数组进⾏操作。
示例 1:
输⼊: nums = [0,1,0,3,12]
输出: [1,3,12,0,0]
示例 2:
输⼊: nums = [0]
输出: [0]
-3、解法(快排思想:数组划分区间 - 数组分成两块):
算法思路:
在本题中,我们可以⽤⼀个 cur 指针来扫描整个数组,另⼀个 dest 指针⽤来记录⾮零数序列的最后⼀个位置。根据 cur 在扫描的过程中,遇到的不同情况,分类处理,实现数组的划分。在 cur 遍历期间,使 [0, dest] 的元素全部都是⾮零元素, [dest + 1, cur - 1] 的元素全是零。
算法流程:
1、初始化 cur = 0 (⽤来遍历数组), dest = -1 (指向⾮零元素序列的最后⼀个位置。因为刚开始我们不知道最后⼀个⾮零元素在什么位置,因此初始化为 -1 )
2、cur 依次往后遍历每个元素,遍历到的元素会有下⾯两种情况:
C++算法代码:
class Solution {
public:
void moveZeroes(vector& nums) {
int cur = 0, dest = -1;
for(cur = 0;cur < nums.size();cur ++)
{
if(nums[cur])
swap(nums[++dest],nums[cur]);
}
}
};
这个⽅法是往后我们学习「快排算法」的时候,「数据划分」过程的重要⼀步。如果将快排算法拆解的话,这⼀段⼩代码就是实现快排算法的「核⼼步骤」。