結果
問題 | No.183 たのしい排他的論理和(EASY) |
ユーザー |
|
提出日時 | 2016-07-04 23:31:56 |
言語 | Go (1.23.4) |
結果 |
AC
|
実行時間 | 272 ms / 5,000 ms |
コード長 | 724 bytes |
コンパイル時間 | 10,968 ms |
コンパイル使用メモリ | 221,984 KB |
実行使用メモリ | 6,340 KB |
最終ジャッジ日時 | 2024-06-29 14:05:44 |
合計ジャッジ時間 | 12,403 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 18 |
ソースコード
package main import ( "fmt" "strings" "strconv" ) func main() { var N int fmt.Scan(&N) A := make([]int, N) for i := 0; i < N; i++ { fmt.Scan(&A[i]) } var dp = make([]bool, 1 << 15) dp[0] = true for i := 0; i < N; i++ { var nextDP = make([]bool, 1 << 15) for k := 0; k < len(dp); k++ { if dp[k] { nextDP[k] = true nextDP[k ^ A[i]] = true } } dp = nextDP } var sum = 0 for k := 0; k < len(dp); k++ { if dp[k] { sum++ } } PrintI(sum) } func PrintI(args ...int) { fmt.Println(strings.Join(mapToString(args), " ")) } func mapToString(arr []int) []string { ret := make([]string, len(arr)) for i := 0; i < len(arr); i++ { ret[i] = strconv.Itoa(arr[i]) } return ret }