Golang | Leetcode Golang题解之第462题最小操作次数使数组元素相等II

题目:

题解:

Go 复制代码
func partition(a []int, l, r int) int {
    x := a[r]
    i := l - 1
    for j := l; j < r; j++ {
        if a[j] <= x {
            i++
            a[i], a[j] = a[j], a[i]
        }
    }
    a[i+1], a[r] = a[r], a[i+1]
    return i + 1
}

func randomPartition(a []int, l, r int) int {
    i := rand.Intn(r-l+1) + l
    a[i], a[r] = a[r], a[i]
    return partition(a, l, r)
}

func quickSelect(a []int, l, r, index int) int {
    q := randomPartition(a, l, r)
    if q == index {
        return a[q]
    }
    if q < index {
        return quickSelect(a, q+1, r, index)
    }
    return quickSelect(a, l, q-1, index)
}

func minMoves2(nums []int) (ans int) {
    rand.Seed(time.Now().UnixNano())
    x := quickSelect(nums, 0, len(nums)-1, len(nums)/2)
    for _, num := range nums {
        ans += abs(num - x)
    }
    return
}

func abs(x int) int {
    if x < 0 {
        return -x
    }
    return x
}
相关推荐
白白白白白kkk13 分钟前
【力扣算法题】每天一道,健康生活
算法·leetcode
bencolyy1 小时前
Golang 中的强大 TUI 库 ——tview
golang
硕风和炜1 小时前
【LeetCode: 134. 加油站 | 贪心算法】
java·算法·leetcode·贪心算法
sjsjs112 小时前
【动态规划-最长公共子序列(LCS)】力扣97. 交错字符串
算法·leetcode·动态规划
福楠3 小时前
[LeetCode] 143. 重排链表
数据结构·c++·算法·leetcode·链表
大二转专业3 小时前
408算法题leetcode--第29天
考研·算法·leetcode
周方.4 小时前
27. 移除元素
java·数据结构·算法·leetcode·排序算法
练习两年半的工程师5 小时前
LeetCode 151 Reverse Words in a String 解题思路和python代码
python·leetcode
产幻少年7 小时前
golang语法
开发语言·golang
小哈里7 小时前
【虚拟化】内核级虚拟化技术KVM介绍,全/半虚拟化的区别,使用libvirt搭建虚拟化平台(go/java/c++)
java·c++·golang·虚拟化·kvm