atcoder#AGC025B. [AGC025B] RGB Coloring

[AGC025B] RGB Coloring

配点 : 700700

問題文

高橋君はタワーを 11 つ持っており、それは NN 個のブロックが縦一列に重なって構成されています。 はじめすべてのブロックは無色ですが、高橋君はいくつかのブロックを赤色、緑色、青色のいずれかの色で塗ることで、 タワーを美しくしようとしています。そこで、高橋君は タワーの美しさ を以下のように定義することにしました。

  • 各ブロックの得点を、赤色に塗られていれば AA 点、緑色に塗られていれば A+BA+B 点、青色に塗られていれば BB 点、無色ならば 00 点として、 NN 個のブロックの得点の合計をタワーの美しさとする。

ただし、A,BA,B はあらかじめ与えられる正整数の定数であり、各マスが 22 つ以上の色で同時に塗られることがないことにも注意してください。

高橋君はタワーの美しさがちょうど KK になるようにブロックを塗ろうと考えています。 そのようにタワーを塗る方法は何通りあるでしょうか。 998244353998244353 で割った余りを求めてください。 ただし、22 つのタワーを塗る方法が異なるとは、あるブロックが存在し、そのブロックに塗られている色が異なること、もしくは、そのブロックが一方では塗られているが、 他方では無色であることを指します。

制約

  • 1N3×1051 \leq N \leq 3 \times 10^5
  • 1A,B3×1051 \leq A,B \leq 3 \times 10^5
  • 0K18×10100 \leq K \leq 18 \times 10^{10}
  • 入力される値は全て整数である

入力

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

NN AA BB KK

出力

タワーを塗る方法の個数を 998244353998244353 で割った余りを出力せよ。

4 1 2 5
40

この場合、赤色 11 つにつき 11 点、緑色 11 つにつき 33 点、青色 11 つにつき 22 点なので、美しさが 55 になるのは、

  • 緑色 11 つ、青色 11
  • 赤色 11 つ、青色 22
  • 赤色 22 つ、緑色 11
  • 赤色 33 つ、青色 11

のいずれかの場合だけです。よって、求める答えは 4040 になります。

2 5 6 0
1

美しさが 00 であるタワーは、すべてのブロックが無色であるものだけです。よって、答えは 11 になります。

90081 33447 90629 6391049189
577742975