力扣100-移动0

方法1 双指针、

代码1

java 复制代码
public  void  moveZeroes(int[] nums) {

        //给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
        //
        //请注意 ,必须在不复制数组的情况下原地对数组进行操作。

       /* 双指针协作:
        slow 指针:指向下一个非零元素应放置的位置。
        fast 指针:遍历数组,寻找非零元素。
        两次遍历:
        第一次遍历:将所有非零元素按原顺序移动到数组前部。
        第二次遍历:将 slow 指针之后的位置全部置为零。*/

        int slow = 0;
        int fast =0 ;
        for(int i = 0 ; i < nums.length;i++){
            //1.快指针寻找非零元素
            //2.慢指针指向下一个非零元素应放置的位置
//            int[] nums = {0, 1, 0, 3, 12};
            while(fast< nums.length ){
                if(nums[fast] != 0){
                    nums[slow] =nums[fast];// 复制非零元素到慢指针位置
                    slow++;
                }
                fast++;
            }
            //进行补0
            while(slow<nums.length){
                nums[slow]=0;
                slow++;
            }
        }

    }

代码优化

java 复制代码
 public void moveZeroes(int[] nums) {
 		//还是一种双指针思路,只是简化了部分代码
        int i =0;
        for(int j =0 ;j<nums.length;j++){
            if(nums[j]!= 0 ){
                //非零元素进行交换
                int temp = nums[j];
                nums[j]=  nums[i];
                nums[i]=temp;
                i++;
            }
        }
    }

方法二 把 nums 当作栈

java 复制代码
//用一个栈记录非零元素。
//入栈就是把 nums[stackSize] 置为 nums[i],同时把 stackSize 加一。

//最后把 nums 中的下标从 stackSize 到 n−1 的数都置为 0。


 public void moveZeroes(int[] nums) {
        int stackSize = 0; 
        for(int x : nums){
            if(x != 0){
                 nums[stackSize++] =x;
            }
        }
        Arrays.fill(nums,stackSize,nums.length,0);
    }
相关推荐
Jay200211131 分钟前
【机器学习】23-25 决策树 & 树集成
算法·决策树·机器学习
dragoooon3432 分钟前
[优选算法专题九.链表 ——NO.53~54合并 K 个升序链表、 K 个一组翻转链表]
数据结构·算法·链表
xlq223227 小时前
22.多态(上)
开发语言·c++·算法
666HZ6667 小时前
C语言——高精度加法
c语言·开发语言·算法
sweet丶7 小时前
iOS MMKV原理整理总结:比UserDefaults快100倍的存储方案是如何炼成的?
算法·架构
云里雾里!8 小时前
力扣 209. 长度最小的子数组:滑动窗口解法完整解析
数据结构·算法·leetcode
CoderYanger9 小时前
递归、搜索与回溯-穷举vs暴搜vs深搜vs回溯vs剪枝:12.全排列
java·算法·leetcode·机器学习·深度优先·剪枝·1024程序员节
憨憨崽&9 小时前
进击大厂:程序员必须修炼的算法“内功”与思维体系
开发语言·数据结构·算法·链表·贪心算法·线性回归·动态规划
自动化测试薰儿9 小时前
软件测试经典面试题整理(一)
软件测试·职场和发展
chem411110 小时前
C 语言 函数指针和函数指针数组
c语言·数据结构·算法