1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
// @Title: 二倍数对数组 (Array of Doubled Pairs)
// @Author: 15816537946@163.com
// @Date: 2022-04-01 22:45:08
// @Runtime: 64 ms
// @Memory: 9.4 MB
func canReorderDoubled(arr []int) bool {
    cnt := make(map[int]int, len(arr))
    for _, x := range arr {
        cnt[x]++
    }
    if cnt[0]%2 == 1 {
        return false
    }

    vals := make([]int, 0, len(cnt))
    for x := range cnt {
        vals = append(vals, x)
    }
    sort.Slice(vals, func(i, j int) bool { return abs(vals[i]) < abs(vals[j]) })

    for _, x := range vals {
        if cnt[2*x] < cnt[x] { // 无法找到足够的 2x 与 x 配对
            return false
        }
        cnt[2*x] -= cnt[x]
    }
    return true
}

func abs(x int) int {
    if x < 0 {
        return -x
    }
    return x
}