首页 > 其他分享 >leetcode-280. 摆动数组

leetcode-280. 摆动数组

时间:2024-06-02 20:10:35浏览次数:19  
标签:nums 交换 数组 摆动 280 leetcode

给你一个的整数数组 nums, 将该数组重新排序后使 nums[0] <= nums[1] >= nums[2] <= nums[3]... 

简单想法

  1. 排序
  2. 双指针,一前一后插入

贪心?猜的

假定前 i 个已经摆动,i + 1 存在奇、偶两种情况

  1. 奇数 —— 若 nums[i+1] >= nums[i+2] 则符合条件,若 nums[i+1] < nums[i+2],尝试交换后发现 nums[i] < nums[i+2] > nums[i+1] ,完美符合
  2. 偶数 —— 若 nums[i+1] <= nums[i+2] 则符合条件,若 nums[i+1] > nums[i+2], 尝试交换后发现 nums[i] > nums[i+2] < nums[i+1],完美符合
    所以这就构成了归纳法的所需要的要素,代码也就很容易写了——对于 i 和 i + 1,查看是否符合条件,不符合则直接交换

标签:nums,交换,数组,摆动,280,leetcode
From: https://www.cnblogs.com/wyzwsy/p/18227542

相关文章

  • LeetCode //C - 147. Insertion Sort List
    147.InsertionSortListGiventheheadofasinglylinkedlist,sortthelistusinginsertionsort,andreturnthesortedlist’shead.Thestepsoftheinsertionsortalgorithm:Insertionsortiterates,consumingoneinputelementeachrepetitionand......
  • leetcode-624.数组列表中的最大距离
    数组列表中的最大距离给定m个数组,每个数组都已经按照升序排好序了。现在你需要从两个不同的数组中选择两个整数(每个数组选一个)并且计算它们的距离。两个整数a和b之间的距离定义为它们差的绝对值|a-b|。你的任务就是去找到最大距离目标题意中的绝对值|a-b|等价于选取......
  • Day 9:2829. k-avoiding 数组的最小总和
    Leetcode2829.k-avoiding数组的最小总和给你两个整数n和k。对于一个由不同正整数组成的数组,如果其中不存在任何求和等于k的不同元素对,则称其为k-avoiding数组。返回长度为n的k-avoiding数组的可能的最小总和。n个不同正整数的最小总和,那就是从1......
  • Leetcode 3161. 物块放置查询
    https://leetcode.cn/problems/block-placement-queries/description/有一条无限长的数轴,原点在0处,沿着x轴正方向无限延伸。给你一个二维数组queries,它包含两种操作:操作类型1:queries[i]=[1,x]。在距离原点x处建一个障碍物。数据保证当操作执行的时候,位置x处......
  • C语言刷题(数组)
    1.编写程序利用数组实现将一个数插入到一个有序的数列中,要求插入后仍有序。C语言代码#include<stdio.h>intmain(){intn=0;printf("请输入有序数组元素的个数:\n");scanf("%d",&n);//定义并输入数组intnum[n];printf......
  • 【leetcode】——第 400 场周赛,2题选手签个到
    第一题:100307.候诊室中的最少椅子数给你一个字符串 s,模拟每秒钟的事件 i:如果 s[i]=='E',表示有一位顾客进入候诊室并占用一把椅子。如果 s[i]=='L',表示有一位顾客离开候诊室,从而释放一把椅子。返回保证每位进入候诊室的顾客都能有椅子坐的 最少 椅子数,假设候诊室......
  • 树状数组题单记录
    树状数组题单笔记[SDOI2009]HH的项链题目思路普通的scanf已经承受不住了,请使用关闭流同步的cin和cout或者经典快读以下假设你已经使用了标准命名空间:参考快读:inlineintread(){intx=0,f=1;charch=getchar();while(ch<'0'||ch>'9'){if(ch=='-')f=-1;......
  • leetCode.89. 格雷编码
    leetCode.89.格雷编码题目思路代码classSolution{public:vector<int>grayCode(intn){vector<int>res(1,0);//n=0时,之后一位0while(n--){//想要实现对象超下来,就从末尾开始,让vector里面加元素for(......
  • leetCode.90. 子集 II
    leetCode.90.子集II题目思路代码classSolution{public:vector<vector<int>>res;vector<int>path;vector<vector<int>>subsetsWithDup(vector<int>&nums){//先排序,让有相同元素的都放到一起sort(nums.be......
  • [补题记录]LeetCode 6.Z字形变换
    传送门:Z字形变换转自:Z字形变换Thought/思路关键点在于,最后的答案是一行行连接起来的。这样我们就会发现,这个Z字,实际上会让行数不断加1,然后又不断减1。每次按顺序选择S中的一个字符即可。Code/代码classSolution{public:stringconvert(strings,int......