给你一个没有排序的数组,请将原数组就地重新排列满足如下性质:
nums[0] <= nums[1] >= nums[2] <= nums[3]....
样例
给出数组为 nums = [3, 5, 2, 1, 6, 4]
一种输出方案为 [1, 6, 2, 5, 3, 4]
解析:如果按照从1排序,也就是奇数要比相邻的偶数小。偶数要比相邻的奇数大。否则就的交换位置。
public class Solution {
/*
* @param nums: A list of integers
* @return: nothing
*/
public void wiggleSort(int[] nums) {
// write your code here
for(int i=1;i<nums.length;i++){
if((i%2==1)&&nums[i]<nums[i-1] || (i%2==0)&&(nums[i]>nums[i-1])){
swap(nums,i-1,i);
}
}
}
public void swap(int[] nums, int i, int j) {
int temp = nums[i];
nums[i] = nums[j];
nums[j] = temp;
}
}