-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1744D.go
125 lines (116 loc) · 1.64 KB
/
1744D.go
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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
package main
import (
"bufio"
"fmt"
"os"
"sort"
)
var in, out = bufio.NewReader(os.Stdin), bufio.NewWriter(os.Stdout)
func solve() {
n := _readInt()
var cnt, res int
for i := 0; i < n; i++ {
x := _readInt()
for x > 0 && x%2 == 0 {
x /= 2
cnt++
}
}
if cnt >= n {
_print(0)
return
}
counts := make([]int, 0)
for i := 1; i <= n; i++ {
x := i
if x%2 != 0 {
continue
}
var tmp int
for x > 0 && x%2 == 0 {
x /= 2
tmp++
}
counts = append(counts, tmp)
}
sort.Ints(counts)
_reverseInts(counts)
for _, v := range counts {
res++
cnt += v
if cnt >= n {
_print(res)
return
}
}
_print(-1)
}
func main() {
defer out.Flush()
var t int
for fmt.Fscanln(in, &t); t > 0; t-- {
solve()
}
}
// ====
func _readInt() int {
var x int
fmt.Fscan(in, &x)
return x
}
func _readStr() string {
var x string
fmt.Fscan(in, &x)
return x
}
func _readArr() (int, []int) {
var n int
fmt.Fscan(in, &n)
var v = make([]int, n)
for i := 0; i < n; i++ {
fmt.Fscan(in, &v[i])
}
return n, v
}
func _print(x ...any) {
fmt.Fprintln(out, x...)
}
func _max(x, y int) int {
if x > y {
return x
}
return y
}
func _min(x, y int) int {
if x < y {
return x
}
return y
}
func _abs(x int) int {
if x < 0 {
return -x
}
return x
}
func _sortStr(x string) string {
r := []rune(x)
sort.Slice(r, func(i, j int) bool {
return r[i] < r[j]
})
return string(r)
}
func _reverseInts(x []int) {
n := len(x)
for i := 0; i < n/2; i++ {
x[i], x[n-1-i] = x[n-1-i], x[i]
}
}
func _reverseStr(s string) string {
x := []rune(s)
n := len(x)
for i := 0; i < n/2; i++ {
x[i], x[n-1-i] = x[n-1-i], x[i]
}
return string(x)
}