leetcode283-Move Zeroes

这道题目要求把所有的0元素都放到数组末尾,并且不能改变数组其它元素的相对数序,类似这种题目思维一定要往快慢指针上靠,快指针从头到尾遍历,快指针永远去找非0元素,慢指针则从头开始遍历,找到以后交换俩个元素的位置,然后俩个指针分别往前走一步。注意这里如果慢指针的策略是永远去找0元素的话,那么就会涉及到一些和快指针的比较,只有在慢指针比快指针小的时候所指向的元素才可以交换,cpu时间会更高一点

java 复制代码
public class moveZeroes {
	public static void main(String[] args) {
		int[] arr = {0,1,0,3,12};
		moveZero(arr);
		for(int i = 0;i<arr.length;i++) {
			System.out.println(arr[i]);
		}
	}
	public static void moveZero(int[] arr) {
		for(int i = 0,j=0;i<arr.length;i++) {
			if(arr[i] != 0) {
				int tmp = arr[i];
				arr[i] = arr[j];
				arr[j] = tmp;
				j++;
			}
		}
	}
}
相关推荐
Alson_Code2 分钟前
Spring Ai Alibaba
java·人工智能·spring
计算机安禾3 分钟前
【c++面向对象编程】第5篇:类与对象(四):赋值运算符重载
java·前端·c++
样例过了就是过了7 分钟前
LeetCode热题100 颜色分类
c++·算法·leetcode
ZPC82109 分钟前
C++ 跨平台 UDP 收发测试程序
c++·算法·机器人
如君愿9 分钟前
考研复习 Day 34 | 习题--计算机网络 第六章(应用层 下)、数据结构 查找算法(下)
数据结构·计算机网络·考研·课后习题
Languorous.9 分钟前
数据结构初阶|二叉树入门,从零到一吃透基础
数据结构
AI人工智能+电脑小能手11 分钟前
【大白话说Java面试题 第45题】【JVM篇】第5题:JVM中,对象何时会进入老年代?
java·开发语言·jvm·后端·面试
ym_xixi14 分钟前
《类和对象》—— 构造函数与析构函数总结
前端·c++·算法
洛水水14 分钟前
【力扣100题】19. 排序链表 | 归并排序详解
算法·leetcode·链表
luck_bor15 分钟前
使用接口定义规范,实现类完成具体逻辑
java·开发语言