408算法题leetcode--第七天

283. 移动零

  • 283. 移动零
  • 思路:代码中注释阐述
  • 时间:O(n);空间:O(1)
cpp 复制代码
class Solution {
public:
    void moveZeroes(vector<int>& nums) {
        // 简单思路:用一个辅助数组,将非0元素复制到里面
        // 双指针,一个p指向结果数组,一个q指向原数组
        // q找到非0元素,移动到p中
        int p = 0, q = 0;
        int size = nums.size();
        while(q < size){
            if(nums[q] != 0){
                int temp = nums[p];
                nums[p] = nums[q];
                nums[q] = temp;
                ++p;
            }
            ++q;
        }
    }
};

88. 合并两个有序数组

cpp 复制代码
class Solution {
public:
    void merge(vector<int>& nums1, int m, vector<int>& nums2, int n) {
        // 逆序双指针:123000 456 > 123006 > 123056 > 123456
        int p = m - 1, q = n - 1;
        int tail = m + n - 1;  // 存放于nums1的最后的位置
        while(p >= 0 && q >= 0){
            if(nums1[p] > nums2[q]){
                nums1[tail--] = nums1[p--];
            } else {
                nums1[tail--] = nums2[q--];
            }
        }
        while(q >= 0){
            nums1[tail--] = nums2[q--];
        }
    }
};
相关推荐
vibecoding日记16 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr213818 小时前
Verilog参数化游程编码RLE模块
算法
望易18 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络1 天前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron2 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩2 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹2 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术2 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望2 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法