結果

問題 No.1751 Fortune Nim
ユーザー tamato
提出日時 2021-11-19 22:25:41
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 98 ms / 2,000 ms
コード長 811 bytes
コンパイル時間 154 ms
コンパイル使用メモリ 82,980 KB
実行使用メモリ 106,172 KB
最終ジャッジ日時 2025-01-01 19:05:29
合計ジャッジ時間 3,853 ms
ジャッジサーバーID
(参考情報)
judge5 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #

mod = 998244353
eps = 10**-9


def main():
    import sys
    input = sys.stdin.readline

    N = int(input())
    A = list(map(int, input().split()))

    if N == 1:
        print(665496236)
    else:
        S = sum(A)
        g = 0
        for a in A:
            g ^= a
        if g:
            ma = 0
            for a in A:
                if a >= a ^ g:
                    ma = max(ma, (a - (a ^ g)))
            S -= ma
            S += 1
            lower = pow(3, S, mod)
            upper = ((lower + 1) * pow(2, mod-2, mod))%mod
            print((upper * pow(lower, mod-2, mod))%mod)
        else:
            lower = pow(3, S, mod)
            upper = ((lower - 1) * pow(2, mod - 2, mod)) % mod
            print((upper * pow(lower, mod - 2, mod)) % mod)


if __name__ == '__main__':
    main()
0