算法:双指针系列(一)

双指针系列

一、移动零

点击跳往题目

(一)题目分析

将数组分为三个区域(已遍历非零区, 已遍历零区,未遍历区),用两个指针来维护这三个区域。

(二)代码展示

cpp 复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        int des = -1, cur = 0;
        while(cur < nums.size()){
            if(nums[cur] != 0) {
                des += 1;
                swap(nums[cur], nums[des]);
            }
            cur += 1;
        }
        //nums.resize(des + 1);
    }
};

二、复写零

(一)题目分析

这道题目中,也是采取双指针进行复写。我们可以开辟一段新空间复写比较简单,题目要求在原生空间复写。如果此时直接使用双指针会导致数组空间覆盖,可以先用双指针遍历找到复写的最后一个元素,反向复写,这样就不会出现问题。

(二)代码展示

cpp 复制代码
class Solution {
public:
    void duplicateZeros(vector<int>& arr) {
        int cur = -1, dest = -1;
        while (dest < ((int)arr.size() - 1)) {
            if (!arr[++cur]) dest++;
            dest++;
        }
        if (dest == arr.size()) {
            arr[--dest] = 0;
            dest--;
            cur--;
        }
        while (cur >= 0) {
            if (arr[cur] == 0) arr[dest--] = 0;
            arr[dest--] = arr[cur--];
        }
    }
};

三、快乐数

(一)题目分析

我们将这道题可以与链表的判环问题结合起来,要么存在循环,要么这个数就是快乐数。

只需要创建一个getNext 函数即可。

(二)代码展示

cpp 复制代码
class Solution {
public:
    int getNext(int val) {
        int ret = 0;
        while (val > 0) {
            int temp = val % 10;
            ret = temp * temp + ret;
            val /= 10;
        }
        return ret;
    }

    bool isHappy(int n) {
        int fast = getNext(n), slow = n;
        while (fast != 1 && fast != slow) {
            fast = getNext(getNext(fast));
            slow = getNext(slow);
        }
        return fast == 1;
    }
};

(四)总结

涉及到元素的移动,数组的分区,亦或是判断是否有环(追击问题),双指针是不错的选择。

相关推荐
wzx_Eleven5 分钟前
【论文阅读】Towards Privacy-Enhanced and Robust Clustered Federated Learning
论文阅读·人工智能·算法·机器学习·支持向量机·网络安全
旭意21 分钟前
C++微基础蓝桥杯之旅9.9-9.12
c++·算法·蓝桥杯
地平线开发者37 分钟前
工具链部署实用技巧 7|模型设计帧率推理时耗时与带宽分析
算法·自动驾驶
lifallen42 分钟前
Hadoop MapOutputBuffer:Map高性能核心揭秘
java·大数据·数据结构·hadoop·算法·apache
溟洵1 小时前
【 C/C++ 算法】入门动态规划-----一维动态规划基础(以练代学式)
c语言·c++·算法
打不了嗝 ᥬ᭄1 小时前
【Linux】线程同步与互斥
linux·服务器·c++
过河卒_zh15667661 小时前
9.12AI简报丨腾讯投资AI游戏平台,B站开源AniSora V3
人工智能·算法·游戏·aigc·算法备案·生成合成类算法备案
boonya1 小时前
Java垃圾回收机制理论算法及使用
jvm·算法·gc·垃圾收集器·理论
愚润求学1 小时前
【贪心算法】day9
c++·算法·leetcode·贪心算法
lingran__2 小时前
速通ACM省铜第二天 赋源码(Adjacent XOR和Arboris Contractio)
c++·算法