結果
| 問題 |
No.2397 ω冪
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-07-28 23:07:17 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,184 bytes |
| コンパイル時間 | 276 ms |
| コンパイル使用メモリ | 82,304 KB |
| 実行使用メモリ | 118,084 KB |
| 最終ジャッジ日時 | 2024-10-06 21:06:52 |
| 合計ジャッジ時間 | 45,206 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 25 WA * 15 RE * 1 |
ソースコード
from collections import defaultdict
order = [0, 1]
def toCnt(x):
if x == 0:return defaultdict(int)
k = 0
while x % 2 == 0:
x //= 2
k += 1
tmp = toCnt(x // 2)
tmp[k] += 1
return tmp
# x > y
def gt(x, y):
xCnt = toCnt(x)
yCnt = toCnt(y)
for p in order[::-1]:
if xCnt[p] > yCnt[p]:
return True
if xCnt[p] < xCnt[p]:
return False
return False
for i in range(2, 20):
k = 0
while k < len(order) and gt(i, order[k]):
k += 1
order.insert(k, i)
def toCnt2(x):
xCnt = toCnt(x)
cnt = [0] * 20
for i in range(20):
cnt[order.index(i)] = xCnt[i]
return cnt[::-1]
order2 = sorted(range(10**5), key=toCnt2)
rank = [0] * (10**5)
for i in range(10**5):
rank[order2[i]] = i
def cnt3(N):
nOne = []
for i in range(len(N)):
if(N[i] == '1'):
nOne.append(i)
nOne.append(len(N))
nCnt = [0] * (10 ** 5)
for i in range(len(nOne) - 1):
nCnt[rank[nOne[i+1] - nOne[i]]] += 1
return nCnt[::-1]
nCnt = cnt3(input())
mCnt = cnt3(input())
if nCnt < mCnt:
print("Yes")
else:
print("No")