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--];
        }
    }
};
相关推荐
咚咚王者37 分钟前
人工智能之RAG工程 第一章 RAG 基础与前置知识
人工智能·算法
handler0140 分钟前
【算法模板】最小生成树:稠密图选 Prim,稀疏图选 Kruskal
c语言·数据结构·c++·算法
Chase_______1 小时前
LeetCode 2461 & 1423:定长滑窗变体精讲,从 HashMap 判重到正难则反的转化技巧
算法·leetcode·职场和发展
WL_Aurora1 小时前
【每日一题】二分算法
python·算法
昵称小白1 小时前
子串专题部分
数据结构·算法·哈希算法
H_BB2 小时前
第17届蓝桥杯备战历程
c++·算法·职场和发展·蓝桥杯
anew___2 小时前
算法分析与设计课程全算法核心概述|期末复习+知识梳理
算法
daad7772 小时前
记录一次上下文切换次数的统计
服务器·c++·算法
fliter2 小时前
Cloudflare 推出 Flagship:为 AI 时代重新设计的功能开关服务
后端·算法
生成论实验室2 小时前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》第十七章 科学与人心的重聚
人工智能·算法·架构·知识图谱·创业创新