結果
問題 | No.3 ビットすごろく |
ユーザー |
![]() |
提出日時 | 2020-05-26 21:06:10 |
言語 | Go (1.23.4) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,904 bytes |
コンパイル時間 | 12,837 ms |
コンパイル使用メモリ | 220,140 KB |
実行使用メモリ | 10,164 KB |
最終ジャッジ日時 | 2024-10-13 03:00:32 |
合計ジャッジ時間 | 18,691 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 8 TLE * 1 -- * 24 |
ソースコード
package mainimport ("bufio""fmt""math""os""strconv")func getScanner(fp *os.File) *bufio.Scanner {scanner := bufio.NewScanner(fp)scanner.Split(bufio.ScanWords)scanner.Buffer(make([]byte, 1000005), 1000005)return scanner}func getNextString(scanner *bufio.Scanner) string {scanner.Scan()return scanner.Text()}func getNextInt(scanner *bufio.Scanner) int {i, _ := strconv.Atoi(getNextString(scanner))return i}func getNextInt64(scanner *bufio.Scanner) int64 {i, _ := strconv.ParseInt(getNextString(scanner), 10, 64)return i}func getNextUint64(scanner *bufio.Scanner) uint64 {i, _ := strconv.ParseUint(getNextString(scanner), 10, 64)return i}func getNextFloat64(scanner *bufio.Scanner) float64 {i, _ := strconv.ParseFloat(getNextString(scanner), 64)return i}func main() {fp := os.Stdinwfp := os.Stdoutcnt := 0if os.Getenv("MASPY") == "ますピ" {fp, _ = os.Open(os.Getenv("BEET_THE_HARMONY_OF_PERFECT"))cnt = 2}if os.Getenv("MASPYPY") == "ますピッピ" {wfp, _ = os.Create(os.Getenv("NGTKANA_IS_GENIUS10"))}scanner := getScanner(fp)writer := bufio.NewWriter(wfp)solve(scanner, writer)for i := 0; i < cnt; i++ {fmt.Fprintln(writer, "-----------------------------------")solve(scanner, writer)}writer.Flush()}func solve(scanner *bufio.Scanner, writer *bufio.Writer) {n := getNextInt(scanner)m := make([]int, n+1)for i := 0; i < n; i++ {m[i] = math.MaxInt32}dfs(n, 0, m)if m[1] == math.MaxInt32 {fmt.Fprintln(writer, -1)return}fmt.Fprintln(writer, m[1]+1)}func dfs(n, c int, m []int) {if c > m[n] {return}m[n] = cif n == 1 {return}for i := 1; i <= 16; i++ {if n-i > 0 && popc(n-i) == i {dfs(n-i, c+1, m)}if n+i < len(m) && popc(n+i) == i {dfs(n+i, c+1, m)}}}func popc(x int) int {i := 0for x > 0 {i += x % 2x >>= 1}return i}