結果
| 問題 |
No.1869 Doubling?
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2022-10-05 02:34:56 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 420 bytes |
| コンパイル時間 | 466 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 189,196 KB |
| 最終ジャッジ日時 | 2024-12-30 19:46:40 |
| 合計ジャッジ時間 | 42,715 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 30 TLE * 13 |
ソースコード
import sys
import math
sys.setrecursionlimit(67108864)
n,m=list (map(int,input ().split()))
def f(x,y):
def a(x,y):
return min(2**(x-1),y,)
if x==1:
return 1
elif y==1:
return x
elif 2**(x-1)<=y:
return 2**x-1
elif y%2==0:
yy=int(y/2)
return f(x-1,yy)+a(x-1,yy)*2
else:
yy=math.ceil(y/2)
return f(x-1,yy)+a(x-1,yy)*2-1
print(f(n,m))