峰与谷00

题目链接

峰与谷

题目描述

注意点

  • nums.length <= 10000

解答思路

  • 首先想到的是将数组中的元素都存到优先队列中,然后取一半的元素插入到数组奇数位置,再将剩下一半的元素插入到数组偶数位置即可,但是时间上并不理想
  • 参照题解可以从局部谷-峰-谷到全局谷-峰-谷,保证遍历过的前部分都满足谷-峰-谷。从第一个位置开始,通过其与后一个元素的大小关系确定其是是峰还是谷,后一个元素也以相同方式确认是峰还是谷,如果相邻两个元素都是峰或谷,因为前面的所有元素已经满足谷-峰-谷,所以可以将后两个元素交换位置,重复上述过程遍历完整个数组即可

代码

java 复制代码
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;
    }
}

关键点

  • 找到局部谷-峰-谷到全局谷-峰-谷的规律
相关推荐
星火开发设计8 分钟前
关联式容器:set 与 multiset 的有序存储
java·开发语言·前端·c++·算法
追随者永远是胜利者9 分钟前
(LeetCode-Hot100)72. 编辑距离
java·算法·leetcode·职场和发展·go
musenh11 分钟前
springmvc学习
java·学习
啊阿狸不会拉杆13 分钟前
《计算机视觉:模型、学习和推理》第 2 章-概率概述
人工智能·python·学习·算法·机器学习·计算机视觉·ai
石牌桥网管14 分钟前
golang Context介绍
开发语言·算法·golang
Hello.Reader15 分钟前
Flink State Backend 选型、配置、RocksDB 调优、ForSt 与 Changelog 一次讲透
java·网络·数据库
_OP_CHEN16 分钟前
【算法提高篇】(四)线段树之多个区间操作:懒标记优先级博弈与实战突破
算法·蓝桥杯·线段树·c/c++·区间查询·acm、icpc·区间操作
俩娃妈教编程16 分钟前
2025 年 09 月 三级真题(1)--数组清零
c++·算法·gesp真题
人道领域24 分钟前
Maven多环境配置实战指南
java·数据库·spring
AI科技星26 分钟前
时空的几何动力学:基于光速螺旋运动公设的速度上限定理求导与全维度验证
人工智能·线性代数·算法·机器学习·平面