結果

問題 No.262 面白くないビットすごろく
ユーザー fmhrfmhr
提出日時 2015-08-01 00:18:16
言語 Go
(1.22.1)
結果
WA  
実行時間 -
コード長 728 bytes
コンパイル時間 11,341 ms
コンパイル使用メモリ 237,744 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-04-19 03:15:57
合計ジャッジ時間 14,725 ms
ジャッジサーバーID
(参考情報)
judge1 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 WA -
testcase_01 AC 882 ms
5,248 KB
testcase_02 WA -
testcase_03 AC 898 ms
5,376 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

package main

import (
	"fmt"
)

func main() {
	solve()
}

func solve(){
	var N, x uint64
	fmt.Scan(&N)
	x = 1
	count := 0
	for {
		x = x+popcount(x)
		count += 1
		if x >= N{
			break
		}
		if count > 120000000{
			break
		}
	}
	if x == N{
		fmt.Println(count+1)
	}else{
		fmt.Println("-1")
	}
}

func popcount(x uint64) uint64 {
	x = (x & 0x5555555555555555) + ((x & 0xAAAAAAAAAAAAAAAA) >> 1)
	x = (x & 0x3333333333333333) + ((x & 0xCCCCCCCCCCCCCCCC) >> 2)
	x = (x & 0x0F0F0F0F0F0F0F0F) + ((x & 0xF0F0F0F0F0F0F0F0) >> 4)
	x = (x & 0x00ff00ff00ff00ff) + ((x & 0xff00ff00ff00ff00) >> 8)
	x = (x & 0x0000ffff0000ffff) + ((x & 0xffff0000ffff0000) >> 16)
	x = (x & 0x00000000ffffffff) + ((x & 0xffffffff00000000) >> 32)
	return x
}
0