移动零(Java)

移动零

题目大意

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

解题思路一

使用双指针

  • 确定数组元素,输入数组
  • 对数组元素进行移动
    移动的思路:
    ①设两个索引index1,index2,
    ② index1指向当前数组下标元素(表示移动后非0元素的数组下标),index2作为遍历数组时的指向下标
    ③下标都从0开始,
    1)若index2==0,则index1继续指向当前位置,index2++
    2)若index2!=0,则将index2指向元素移动到index1指向的位置
    【即index2一直往后找,找到一个非0元素就往前移,因此结束循环时index1正好等于非0元素的个数, index2正好等于数组元素的个数】
  • 对数组进行输出

代码实现

import java.util.Scanner;
/*
移动零 
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
 */
public class MoveZero{

	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		System.out.print("请输入数组nums的大小:");
		int num = input.nextInt();
		int[] nums = new int[num];
		System.out.print("请输入" + num + "个整数:");
		for (int i = 0; i < nums.length; i++) {	// 通过循环输入num个整数,构成数组
			nums[i] = input.nextInt();
		}
		/*
		 * 移动的思路: 设两个索引index1,index2,
		 * index1指向当前数组下标元素(表示移动后非0元素的数组下标),index2作为遍历数组时的指向下标
		 * 下标都从0开始,①若index2==0,则index1继续指向当前位置,index2++
		 * ②若index2!=0,则将index2指向元素移动到index1指向的位置
		 * (即index2一直往后找,找到一个非0元素就往前移,因此结束循环时index1正好等于非0元素的个数, index2正好等于数组元素的个数)
		 */
		int index1 = 0;// 默认都指向第一个元素
		int index2 = 0;
		while (index2 != num) {// 当索引没有指向数组最后一位元素
			if (nums[index2] != 0) {// 如果该位置元素不为0,则移动到index1指向的位置
				nums[index1] = nums[index2];
				index1++;// 两个索引都指向下一个位置
				index2++;
			} else {// 如果index2指向为0,则index2继续后移
				index2++;
			}
		}
		for (int i = index1; i < index2; i++) {// 剩下的元素即index2-index1,也就是0的个数
			nums[i] = 0;
		}
		for (int i = 0; i < index1 - 1; i++) {// 通过冒泡对非0元素进行排序
			for (int j = 0; j < index1 - 1 - i; j++) {
				if (nums[j] > nums[j + 1]) {
					int temp = nums[j];
					nums[j] = nums[j + 1];
					nums[j + 1] = temp;
				}
			}
		}
		// 打印输出
		System.out.print("移动零后的数组为:");
		for (int i = 0; i < nums.length; i++) {
			System.out.print(nums[i] + " ");
		}
		/*
		 * 也可以这样输出
		 * 
		 * 输出非0元素 
		 * for (int i = 0; i < index1; i++){
		 * 		System.out.print(nums[i] + " ");
		 * }
		 *  输出0 
		 * for (int i = index1; i < index2; i++) {
		 * 		System.out.print(nums[i] + " ");
		 * }
		 */
	}
}

解题思路二

  • 确定数组元素,输入数组
  • 通过排序 使得数组有序
  • 通过循环 将0元素移动到最后
    移动的思路:
    由于数组已经排好序,因此0一定是在最前面的,每一次移动时查看第一个元素,如果是0,则后面的元素依次往前移动一次,将0(即此时的第一个元素)移动到数组的最后。
    当第一个元素不为0时,移动完成。(由于之前已经排好序,因此第一个元素不为0时数组已经完成移动)
  • 打印输出

代码实现

import java.util.Scanner;
/*
移动零 
给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。
 */
public class MoveZero {

	public static void main(String[] args) {
		Scanner input = new Scanner(System.in);
		System.out.print("请输入数组nums的大小:");
		int num = input.nextInt();
		int[] nums = new int[num];
		System.out.print("请输入" + num + "个整数:");
		for (int i = 0; i < nums.length; i++) { // 通过循环输入num个整数,构成数组
			nums[i] = input.nextInt();
		}
		// 以上部分与解题思路一一致

		for (int i = 0; i < nums.length - 1; i++) {// 通过冒泡排序使数组有序,易知0在最前面
			for (int j = 0; j < nums.length - i - 1; j++) {
				if (nums[j] > nums[j + 1]) {
					int temp = nums[j];
					nums[j] = nums[j + 1];
					nums[j + 1] = temp;
				}
			}
		}
		// 通过循环来移动0,由于不确定0的个数(即循环次数),因此用while循环
		while (true) {
			int temp = nums[0];// 0最小,因此排序后在最前面,也由此可知当第一个元素不为0时移动完毕
			if (temp == 0) {// 如果第一个元素为0,则通过循环将0后面的元素按序一次前移
				for (int j = 0; j < nums.length - 1; j++) {
					nums[j] = nums[j + 1];
				}
				nums[nums.length - 1] = temp;// 将0移到最后
			} else {
				break;// 由于数组有序,因此当第一个元素为非0时,数组顺序已经符合题意,跳出循环
			}
		}
		System.out.print("移动零后的数组为:");
		for (int i = 0; i < nums.length; i++) {
			System.out.print(nums[i] + " ");
		}
	}
}

运行结果

两种方法的运行结果是一样的

  • Demo1
    在这里插入图片描述
  • Demo2
    在这里插入图片描述
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Selcouther

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值