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++;
			}
		}
	}
}
相关推荐
01二进制代码漫游日记3 分钟前
【C语言数据结构】之解锁双向链表(头插、头删等操作)
c语言·数据结构·学习·链表
GoodStudyAndDayDayUp6 分钟前
优化java加权方法
java·优化java加权方法
阿丰资源6 分钟前
基于SpringBoot+MySQL的时装购物系统(附源码)
java·spring boot·mysql
阿Y加油吧7 分钟前
算法二刷复盘:LeetCode 39 组合总和 & 22 括号生成(Java 回溯精讲)
java·算法·leetcode
WL_Aurora13 分钟前
每日一题——自然倍树
数据结构·python·算法·深度优先
Y学院14 分钟前
Spring AI Alibaba 高质量实战教程(从入门到企业级落地)
java·人工智能·spring·自然语言处理
水木流年追梦19 分钟前
CodeTop Top 300 热门题目3-字符串相加
java·前端·算法
Lazionr19 分钟前
【链表经典OJ-中】
c语言·数据结构·链表
编程之升级打怪20 分钟前
自定义实现Java的HashMap集合
java·开发语言
后端AI实验室22 分钟前
我带的那个实习生,比我更依赖AI——但他的问题和我完全不同
java·ai