算法初阶双指针+C语言期末考试之编程题加强训练

慈云数据 1年前 (2024-03-18) 技术支持 99 0

指针

常⻅的双指针有两种形式,⼀种是对撞指针,⼀种是左右指针。 对撞指针:⼀般⽤于顺序结构中,也称左右指针。 • 对撞指针从两端向中间移动。⼀个指针从最左端开始,另⼀个从最右端开始,然后逐渐往中间逼 近。 • 对撞指针的终⽌条件⼀般是两个指针相遇或者错开(也可能在循环内部找到结果直接跳出循 环),也就是: ◦ left == right (两个指针指向同⼀个位置) ◦ left > right (两个指针错开) 快慢指针:⼜称为⻳兔赛跑算法,其基本思想就是使⽤两个移动速度不同的指针在数组链表序列 结构上移动。 这种⽅法对于处理环形链表或数组⾮常有⽤。 其实不单单是环形链表或者是数组,如果我们要研究的问题出现循环往复的情况时,均可考虑使⽤快 慢指针的思想。 快慢指针的实现⽅式有很多种,最常⽤的⼀种就是: • 在⼀次循环中,每次让慢的指针向后移动⼀位,⽽快的指针往后移动两位,实现⼀快⼀慢。

 

1. 移动零(easy)

「数组分两块」是⾮常常⻅的⼀种题型,主要就是根据⼀种划分⽅式,将数组的内容分成左右两部 分。这种类型的题,⼀般就是使⽤「双指针」来解决。 1. 题⽬链接:283. 移动零 2. 题⽬描述: 给定⼀个数组 nums ,编写⼀个函数将所有 0 移动到数组的末尾,同时保持⾮零元素的相对顺 序。 请注意 ,必须在不复制数组的情况下原地对数组进⾏操作。 ⽰例 1: 输⼊: nums = [0,1,0,3,12] 输出: [1,3,12,0,0] ⽰例 2: 输⼊: nums = [0] 输出: [0] 思路:用cur指针扫描整个数组,另一个dest指针记录非零序列最后一个位置,根据cur扫描过程,分类划分,实现数组的划分,这样使得[0,dest]都是非0元素,[dest+1,cur-1]都是0. 具体实现:
class Solution {
public:
    void moveZeroes(vector& nums) 
    {
        int cur = 0;
        int dest = -1;
        while(cur
微信扫一扫加客服

微信扫一扫加客服