#ARC146C. [ARC146C] Even XOR

[ARC146C] Even XOR

配点 : 600600

問題文

00 以上 2N2^N 未満の非負整数からなる集合 SS のうち、以下の条件を満たすものの個数を 998244353998244353 で割ったあまりを出力してください。

  • SS の空でない部分集合 TT は以下のどちらかを満たす。- TT の要素数が奇数
    • TT の全要素の XOR\mathrm{XOR}00 でない
  • TT の要素数が奇数
  • TT の全要素の XOR\mathrm{XOR}00 でない
$\mathrm{XOR}$ とは

非負整数 $A, B$ のビット単位 $\mathrm{XOR}$$A \oplus B$ は、以下のように定義されます。

  • $A \oplus B$ を二進表記した際の $2^k$ ($k \geq 0$) の位の数は、$A, B$ を二進表記した際の $2^k$ の位の数のうち一方のみが $1$ であれば $1$、そうでなければ $0$ である。
例えば、3 \oplus 5 = 6 となります (二進表記すると: 011 \oplus 101 = 110)。
一般に k 個の整数 p_1, p_2, p_3, \dots, p_k のビット単位 \mathrm{XOR}(\dots ((p_1 \oplus p_2) \oplus p_3) \oplus \dots \oplus p_k) と定義され、これは p_1, p_2, p_3, \dots p_k の順番によらないことが証明できます。

制約

  • 1N2×1051 \le N \le 2 \times 10^5
  • 入力は全て整数である。

入力

入力は以下の形式で標準入力から与えられる。

NN

出力

答えを出力せよ。

2
15

{0,2,3}\lbrace 0,2,3 \rbrace{1}\lbrace 1 \rbrace{}\lbrace \rbrace は条件を満たします。

{0,1,2,3}\lbrace 0,1,2,3 \rbrace は条件を満たしません。

なぜなら、{0,1,2,3}\lbrace 0,1,2,3 \rbrace は部分集合 {0,1,2,3}\lbrace 0,1,2,3 \rbrace が要素数が偶数であり、全要素の XOR\mathrm{XOR}00 であるからです。

146
743874490