算法每日一题 Day01|双指针解决移动零问题

题目名称(附链接)

移动零链接:https://leetcode.cn/problems/move-zeroes/description/

一、题目描述

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

二、思路

利用双指针法来进行解答。

第一步:我们先定义两个指针,一个是cur(从左向右遍历数组),一个是dest(已处理的区间的最后一个元素位置)


第二步:将数组分为三段,第一段数组下标:[0,dest],第二段数组下标:[dest+1,cur-1],第三段下标:[cur,n-1]。

第一段划分出来代表:这个区间是非0元素

第二段划分出来代表:这个区间是0元素

第三段划分出来代表:这个区间是未划分元素区间。


第三步:设置初始值

将dest指针初始位置设为-1;cur初始位置设为0。

如果cur指向的元素为0,cur++,后移,如果cur指向的元素为非0元素,让cur位置的元素和dest+1位置的元素进行交换。一直重复这个动作,直到cur走到数组长度的位置,就完成操作了。

三、关键点

  • 边界条件:注意指针位置的区间取值

四、代码(Java )

java 复制代码
class Solution {
    public void moveZeroes(int[] nums) {
        for (int cur = 0, dest = -1; cur < nums.length; cur++) {
            if (nums[cur] != 0) {
                int tmp = nums[cur];
                nums[cur] = nums[dest + 1];
                nums[dest + 1] = tmp;
                dest++;
            }
        }
    }
}

五、总结

五、总结

  • 这题属于什么类型?

    这道题属于数组处理中的双指针(或数组划分)问题,本质是通过控制指针来对数组进行原地调整。

  • 学到了什么套路?

    通过双指针将数组动态划分为"已处理区"和"未处理区",在遍历过程中不断调整元素位置,从而在不额外使用空间的情况下完成操作。同时也加深了对双指针在数组重排问题中应用的理解。

相关推荐
逸Y 仙X4 分钟前
文章二十一:ElasticSearch 词项查询与调度查询实战
java·大数据·数据库·elasticsearch·搜索引擎
Bechamz4 分钟前
大数据开发学习Day25
java·大数据·学习
风筝在晴天搁浅23 分钟前
剑指Offer 60.n个骰子的点数
算法
ProgramHelpOa28 分钟前
Optiver 2026 OA 全面复盘|26NG / Intern 最新高频题型整理
人工智能·算法·机器学习
feifeigo12328 分钟前
基于无迹变换的电网概率潮流分析 MATLAB 实现
开发语言·算法·matlab
Java成神之路-30 分钟前
【算法刷题笔记】全题型导航目录
笔记·算法
爱写代码的倒霉蛋32 分钟前
2022年天梯赛L1-8真题解析(哈希+排序)
数据结构·算法
Struggle_975539 分钟前
算法知识-倍增算法
算法
计算机安禾42 分钟前
【计算机网络】第5篇:网桥学习与生成树算法——环路拓扑中的路径收敛问题
学习·计算机网络·算法