結果

問題 No.1589 Bit Vector
ユーザー 👑 SPD_9X2SPD_9X2
提出日時 2021-07-09 00:04:56
言語 PyPy3
(7.3.15)
結果
RE  
実行時間 -
コード長 968 bytes
コンパイル時間 162 ms
コンパイル使用メモリ 81,952 KB
実行使用メモリ 66,832 KB
最終ジャッジ日時 2024-07-01 13:23:27
合計ジャッジ時間 9,493 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 RE -
testcase_01 RE -
testcase_02 RE -
testcase_03 RE -
testcase_04 RE -
testcase_05 RE -
testcase_06 RE -
testcase_07 RE -
testcase_08 RE -
testcase_09 RE -
testcase_10 RE -
testcase_11 RE -
testcase_12 RE -
testcase_13 RE -
testcase_14 RE -
testcase_15 RE -
testcase_16 RE -
testcase_17 RE -
testcase_18 RE -
testcase_19 RE -
testcase_20 RE -
testcase_21 RE -
testcase_22 RE -
testcase_23 RE -
testcase_24 RE -
testcase_25 RE -
testcase_26 RE -
testcase_27 RE -
testcase_28 RE -
testcase_29 RE -
testcase_30 RE -
testcase_31 RE -
testcase_32 RE -
testcase_33 RE -
testcase_34 RE -
testcase_35 RE -
権限があれば一括ダウンロードができます

ソースコード

diff #

"""

1がBの中に含まれているかだけわかればよい

a[N]を1にする
全部にXorする
→0が含まれているか?問題になる

全部とANDする。
0が含まれていると、 A[N]は0になる

あとは、
a[0]


ソートしたい
01 -> 01
10 -> 01

右側を1とXORとる
右が1だと何もしない
右が0だと1になる
左とANDをとる
両方にXORする

"""

import sys
from sys import stdin
from collections import deque

ans = []

def UPD(i,x):
    C[i] = x
    print ("UPD",i,x)

def AND(i,j,k):
    C[i] = C[j] & C[k]
    print ("AND",i,j,k)

def XOR(i,j,k):
    C[i] = C[j] ^ C[k]
    print ("XOR",i,j,k)

def SWAP(i):
    UPD(N,1)
    XOR(N,i+1,N)
    AND(N,i,N)
    XOR(i,i,N)
    XOR(i+1,i+1,N)


N,K = int(stdin.readline())
C = [0] * (N+1)

#C = [1,1,0,1,0,0,1,0,0,0,1,0]
#N = len(C)-1

for i in range(N-1,-1,-1):
    for j in range(i+1):
        SWAP(j)

UPD(N,0)
XOR(N,N,N-K)

#print (C)

#T = int(stdin.readline())
0