编写一个Java程序,接受一个整数数组,将数组中所有的奇数放到偶数前面。
时间: 2024-02-11 16:05:23 浏览: 57
调整数组顺序使奇数位于偶数前面.md
好的,下面是实现该功能的Java程序:
```java
public class OddEvenSort {
public static void main(String[] args) {
int[] nums = {1, 2, 3, 4, 5, 6, 7, 8, 9};
sort(nums);
for(int num : nums) {
System.out.print(num + " ");
}
}
public static void sort(int[] nums) {
int left = 0;
int right = nums.length - 1;
while(left < right) {
while(left < right && nums[left] % 2 != 0) {
left++;
}
while(left < right && nums[right] % 2 == 0) {
right--;
}
if(left < right) {
int temp = nums[left];
nums[left] = nums[right];
nums[right] = temp;
}
}
}
}
```
程序的核心是sort方法,使用双指针的方法,left指向数组的左边,right指向数组的右边,然后分别向中间移动,当left指向的数是奇数,right指向的数是偶数时,交换它们的位置,直到left和right相遇为止。这样做可以保证所有奇数都被放到了偶数前面,且不改变原来的相对顺序。
阅读全文