結果
問題 | No.822 Bitwise AND |
ユーザー |
👑 |
提出日時 | 2019-04-26 22:40:37 |
言語 | Lua (LuaJit 2.1.1734355927) |
結果 |
TLE
(最新)
AC
(最初)
|
実行時間 | - |
コード長 | 1,080 bytes |
コンパイル時間 | 37 ms |
コンパイル使用メモリ | 6,820 KB |
実行使用メモリ | 16,696 KB |
最終ジャッジ日時 | 2024-06-25 18:14:53 |
合計ジャッジ時間 | 6,464 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | TLE * 1 -- * 16 |
ソースコード
local n, k = io.read("*n", "*n")-- 2^a + n - (2^a - 1) <= kif(n < k) then print("INF")elselocal len = 0local lastzero = -1local zeropos = {}local tmpn = nwhile(0 < tmpn) dolen = len + 1local s = tmpn % 2if(s == 0) thenlastzero = lentable.insert(zeropos, len)endtmpn = math.floor(tmpn / 2)endif(lastzero == -1) thenprint(1)elselocal allcnt = 0local a_base = 0local arb_count = #zeroposlocal iter = 3^arb_count - 1for i = 0, iter dolocal i_tmp = ilocal a_cand = a_baselocal b_cand = 0local mult = 1for k_tmp = 1, arb_count dolocal s = i_tmp % 3if(s == 0) then a_cand = a_cand + 2^(zeropos[mult] - 1)elseif(s == 1) then b_cand = b_cand + 2^(zeropos[mult] - 1)endmult = mult + 1i_tmp = math.floor(i_tmp / 3)endlocal flg = (b_cand <= a_cand) and (a_cand - b_cand <= k)--print(i, a_cand, b_cand, flg)if(flg) then allcnt = allcnt + 1 endendprint(allcnt)endend