-
Notifications
You must be signed in to change notification settings - Fork 27
/
Copy path10664.go
51 lines (44 loc) · 879 Bytes
/
10664.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
// UVa 10664 - Luggage
package main
import (
"bufio"
"fmt"
"os"
"strings"
)
func knapsack(luggage []int, sum int) bool {
dp := make([]bool, sum+1)
dp[0] = true
for i := range luggage {
for j := sum; j >= luggage[i]; j-- {
dp[j] = dp[j-luggage[i]]
}
}
return dp[sum/2]
}
func solve(token []string) bool {
var sum int
luggage := make([]int, len(token))
for i := range luggage {
fmt.Sscanf(token[i], "%d", &luggage[i])
sum += luggage[i]
}
return sum%2 == 0 && knapsack(luggage, sum)
}
func main() {
in, _ := os.Open("10664.in")
defer in.Close()
out, _ := os.Create("10664.out")
defer out.Close()
s := bufio.NewScanner(in)
s.Split(bufio.ScanLines)
var m int
s.Scan()
for fmt.Sscanf(s.Text(), "%d", &m); m > 0 && s.Scan(); m-- {
if solve(strings.Fields(s.Text())) {
fmt.Fprintln(out, "YES")
} else {
fmt.Fprintln(out, "NO")
}
}
}