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++;
			}
		}
	}
}
相关推荐
2301_8184190112 小时前
C++中的协程编程
开发语言·c++·算法
add45a12 小时前
C++中的工厂方法模式
开发语言·c++·算法
java1234_小锋12 小时前
Java高频面试题:Spring-AOP通知和执行顺序?
java·开发语言·spring
番茄去哪了13 小时前
Java基础面试题day02
java·开发语言·面向对象编程
無限進步D13 小时前
二分算法 cpp
算法
xushichao198913 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
2501_9249526913 小时前
C++模块化编程指南
开发语言·c++·算法
qzhqbb13 小时前
差分隐私与大模型+差分隐私在相关领域应用的论文总结
人工智能·算法
2401_8319207413 小时前
基于C++的爬虫框架
开发语言·c++·算法
我是咸鱼不闲呀13 小时前
力扣Hot100系列22(Java)——[图论]总结(岛屿数量,腐烂的橘子,课程表,实现Trie(前缀树))
java·leetcode·图论