結果
問題 |
No.911 ラッキーソート
|
ユーザー |
![]() |
提出日時 | 2019-12-01 03:14:56 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,159 bytes |
コンパイル時間 | 125 ms |
コンパイル使用メモリ | 12,800 KB |
実行使用メモリ | 78,512 KB |
最終ジャッジ日時 | 2024-11-21 04:08:12 |
合計ジャッジ時間 | 63,875 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 6 WA * 21 TLE * 19 |
ソースコード
import sys input = sys.stdin.readline N,L,R=map(int,input().split()) A=list(map(int,input().split())) ANS=[-1]*62 for i in range(1,N): if A[i]==A[i-1]: print(0) sys.exit() for i in range(61,-1,-1): B=[a>>i for a in A] C=[b^1 for b in B] flagb=1 flagc=1 for j in range(1,N): if B[j-1]>B[j]: flagb=0 if C[j-1]>C[j]: flagc=0 if flagb and flagc: ANS[i]=2 elif flagb: ANS[i]=0 elif flagc: ANS[i]=1 A=[a^(1<<i) for a in A] else: print(0) sys.exit() def calc(N,keta): if N<0: return 0 if keta==-1: return 0 if N & (1<<keta)==0: if ANS[keta]==0: return calc(N,keta-1) elif ANS[keta]==1: return 0 elif ANS[keta]==2: return calc(N,keta-1) else: if ANS[keta]==0: return calc(N,keta-1) elif ANS[keta]==1: return calc(N,keta-1) elif ANS[keta]==2: return calc(N,keta-1)+(1<<(ANS[:keta].count(2))) print(calc(R,60)-calc(L-1,60)+1)