当前位置: 首页 > article >正文

【双指针】283. 移动零

题目
两种方法时间复杂度相同都是O(n),方法2操作更少一些

1.解法1: 有优化空间

class Solution {
    public void moveZeroes(int[] nums) {
        int slow = 0, fast = 0;
        while (fast < nums.length) {
            if (nums[fast] != 0) {
                if (slow == fast) {
                    ++slow;
                    ++fast;
                } else {
                    nums[slow++] = nums[fast++];
                }
            } else {
                ++fast;
            }
        }
        while (slow < nums.length) {
            nums[slow++] = 0;
        }
    }
}

解法2:最佳写法

class Solution {
    public void moveZeroes(int[] nums) {
        int slow = 0, fast = 0;
        while (fast < nums.length) {
            if (nums[fast] != 0) {
                if (nums[slow] != 0) {
                    ++slow;
                    ++fast;
                } else {
                    nums[slow++] = nums[fast];
                    nums[fast++] = 0;
                }
            } else {
                ++fast;
            }
        }
    }
}

http://www.kler.cn/a/154964.html

相关文章:

  • 使用EasyExcel(FastExcel) 的模板填充报Create workbook failure
  • 专为课堂打造:宏碁推出三款全新耐用型 Chromebook
  • 数据结构:二叉树—面试题(二)
  • php代码审计2 piwigo CMS in_array()函数漏洞
  • Next.js 实战 (十):中间件的魅力,打造更快更安全的应用
  • SkyWalking介绍
  • 内网穿透工具获取一个公网ip
  • 提高wordpress网站收录速度,设置wp后台的“更新服务”功能
  • 【经验总结】网络关闭但ECU没有休眠前如何网络唤醒
  • Java 使用zxing生成二维码
  • Mybatis实用教程之XML实现动态sql
  • springboot教师进修培训管理系统设计与实现java+jsp
  • PX4 Bug汇总
  • 【Python百练——第3练】矩形类及操作
  • 创建内存泄漏(js的问题)
  • 深入Os--静态链接
  • RabbitMQ 笔记
  • C#拼夕夕自动化登录,电商网页自动化操作。WebView2
  • CSS 选择器优先级,!important 也会被覆盖?
  • 堆排序算法
  • 选股的重要性、考虑的因素
  • MySQL-视图
  • 【学习笔记】GAN实战(基础)
  • 动态规划学习——回文串
  • day4 找到两个链表的交点
  • 用友U8 ERP和面粉行业专版系统接口集成方案