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++;
			}
		}
	}
}
相关推荐
Yolo_TvT几秒前
数据结构:栈
数据结构
yugi9878382 分钟前
TDOA算法MATLAB实现:到达时间差定位
前端·算法·matlab
路边草随风4 分钟前
flink实现写orc对数据进行分目录(分区表)写入
java·大数据·flink
geekmice10 分钟前
通过账户信息操作加深对DTO,VO,BO理解
java
r***013812 分钟前
Java进阶,时间与日期,包装类,正则表达式
java·mysql·正则表达式
t1987512814 分钟前
基于因子图与和积算法的MATLAB实现
开发语言·算法·matlab
le serein —f16 分钟前
用go实现-回文链表
算法·leetcode·golang
APIshop16 分钟前
Java爬虫第三方平台获取1688关键词搜索接口实战教程
java·开发语言·爬虫
k***121717 分钟前
SpringCloud实战【九】 SpringCloud服务间调用
java·spring boot·spring cloud
rit843249919 分钟前
MFOCUSS算法MATLAB实现:稀疏信号重构
算法·matlab·重构