美文网首页
IOS 算法(中级篇) ----- 构造元素不等于两相邻元素平均

IOS 算法(中级篇) ----- 构造元素不等于两相邻元素平均

作者: ShawnAlex | 来源:发表于2021-08-19 12:41 被阅读0次

给你一个 下标从 0 开始 的数组 nums ,数组由若干 互不相同的 整数组成。你打算重新排列数组中的元素以满足:重排后,数组中的每个元素都 不等于 其两侧相邻元素的 平均值 。更公式化的说法是,重新排列的数组应当满足这一属性:对于范围 1 <= i < nums.length - 1 中的每个 i ,(nums[i-1] + nums[i+1]) / 2 不等于 nums[i] 均成立 。
返回满足题意的任一重排结果。
3 <= nums.length <= 105
0 <= nums[i] <= 105

例子

输入: nums = [1,2,3,4,5]
输出: [1,2,4,5,3]
解释:
i=1, nums[i] = 2, 两相邻元素平均值为 (1+4) / 2 = 2.5
i=2, nums[i] = 4, 两相邻元素平均值为 (2+5) / 2 = 3.5
i=3, nums[i] = 5, 两相邻元素平均值为 (4+3) / 2 = 3.5

输入:nums = [6,2,0,9,7]
输出:[9,7,6,2,0]
解释:
i=1, nums[i] = 7, 两相邻元素平均值为 (9+6) / 2 = 7.5
i=2, nums[i] = 6, 两相邻元素平均值为 (7+2) / 2 = 4.5
i=3, nums[i] = 2, 两相邻元素平均值为 (6+0) / 2 = 3

解题思路

滑动窗口(双指针)

其实这道题不难, 思路找对的话很容易处理
我这边是将数组变化为 [小, 大, 小, 大, 小, 大 ......] 这样形式返回

左右2边都比中间小, 那么平均值比中间小
左右2边都比中间大, 那么平均值比中间大
满足题目要求 (nums[i-1] + nums[i+1]) / 2 不等于 nums[I]

1.将数组正序排序
2.设置2个指针, 依次改变
3.指针+2, 从index=1开始以长度为2窗口滑动, 依次把窗口内2个位置互换

例子1 例子2 例子3

代码

未翻译版
    func rearrangeArray(_ nums: [Int]) -> [Int] {
        
        var res = nums.sorted(), last = 1, next = 2
        
        while next < nums.count {
            
            let temp = res[last]
            res[last] = res[next]
            res[next] = temp
            
            last += 2
            next += 2
        }
        
        return res
    }
翻译版
    func rearrangeArray(_ nums: [Int]) -> [Int] {
        
        // 数组正序排序, 并设置2个指针
        var res = nums.sorted(), last = 1, next = 2
        
        // 循环, 滑动窗口
        while next < nums.count {
            
            // 互换位置 
            let temp = res[last]
            res[last] = res[next]
            res[next] = temp
            
            // 指针+2, 滑动窗口
            last += 2
            next += 2
        }
        
        // 返回结果
        return res
    }

题目来源:力扣(LeetCode) 感谢力扣爸爸 :)
IOS 算法合集地址

相关文章

  • IOS 算法(中级篇) ----- 构造元素不等于两相邻元素平均

    给你一个 下标从 0 开始 的数组 nums ,数组由若干 互不相同的 整数组成。你打算重新排列数组中的元素以满足...

  • 冒泡排序

    算法思想 1.比较相邻的两个元素,交换较大的元素到右边2.每次循环比较相邻的两个元素,直到最后一对,最后的元素应该...

  • 2018-07-21

    排序算法之冒泡排序 冒泡排序算法原理:比较两个相邻的元素,将值大的元素交换至右端。 步骤:依次比较相邻的两个数,将...

  • Swift排序算法

    swift 排序算法 冒泡排序 原理:两两相邻元素进行比较,把较小的放到前面 平均时间复杂度为O(n^2),空间复...

  • python实现--五大常用排序算法

    1. 冒泡排序 冒泡算法,从第一个元素开始,每每相邻的两个元素进行比较,若前者比后者大则交换位置。最后两个相邻元素...

  • 冒泡排序

    算法思想 : (升序)将数组 元素 从前到后 遍历,相邻 两个 元素 比较大小 ,若前边的 元素 大于后边 的 元...

  • 算法理解之排序-冒泡排序

    算法理解之排序-冒泡排序 冒泡排序是一种简单的排序算法, 算法依次走访未排序的元素, 然后将相邻元素依次两两比较,...

  • 排序算法【冒泡排序】

    原理 冒泡排序原理: 冒泡排序是较简单的排序算法,它是比较相邻两个元素的大小,并进行交换。 1、两个相邻元素进行比...

  • Objective-C实现冒泡算法

    一,冒泡算法简介 冒泡算法是一种基础的排序算法,这种算法会重复的比较数组中相邻的两个元素。如果一个元素比另一个元素...

  • 必备的手写算法题(一)

    [TOC] 排序算法 冒泡排序 算法步骤 比较相邻的元素。如果第一个比第二个大,就交换他们两个。 对每一对相邻元素...

网友评论

      本文标题:IOS 算法(中级篇) ----- 构造元素不等于两相邻元素平均

      本文链接:https://www.haomeiwen.com/subject/qngobltx.html