题目链接
峰与谷
题目描述
注意点
- nums.length <= 10000
解答思路
- 首先想到的是将数组中的元素都存到优先队列中,然后取一半的元素插入到数组奇数位置,再将剩下一半的元素插入到数组偶数位置即可,但是时间上并不理想
- 参照题解可以从局部谷-峰-谷到全局谷-峰-谷,保证遍历过的前部分都满足谷-峰-谷。从第一个位置开始,通过其与后一个元素的大小关系确定其是是峰还是谷,后一个元素也以相同方式确认是峰还是谷,如果相邻两个元素都是峰或谷,因为前面的所有元素已经满足谷-峰-谷,所以可以将后两个元素交换位置,重复上述过程遍历完整个数组即可
代码
class Solution {
public void wiggleSort(int[] nums) {
if (nums.length < 3) {
return;
}
boolean prev = nums[0] > nums[1] ? true : false;
for (int i = 1; i < nums.length - 1; i++) {
boolean curr = nums[i] > nums[i + 1] ? true : false;
if (prev == curr) {
swap(nums, i, i + 1);
}
prev = !prev;
}
}
public void swap(int[] nums, int m, int n) {
int tmp = nums[m];
nums[m] = nums[n];
nums[n] = tmp;
}
}
关键点
- 找到局部谷-峰-谷到全局谷-峰-谷的规律