#ATarc139e. [ARC139E] Wazir

[ARC139E] Wazir

题目描述

我们有一个 H×WH \times W 的网格图。不妨用 (i,j)(i, j) 来表示从上往下第 ii 行,从左往右第 jj 列的格子。

假设整个网格图是一个环面。也就是说,除了水平或竖直相邻的格子之外,我们认为以下两种情况的格子也是相邻的:

  • (i,1)(i, 1)(i,W)(i, W),其中 1iH1 \leq i \leq H
  • (1,j)(1, j)(H,j)(H, j),其中 1jW1 \leq j \leq W

考虑用碎片将这个网格图上的一些格子覆盖。我们规定,每片碎片最多只能覆盖一个格子,且不能存在两片碎片覆盖了相邻的格子。

LL 表示这个网格图上最多能被同时覆盖的格子数量,你需要求出有多少种方案来放置碎片,使 LL 个格子被覆盖。由于答案可能很大,你只需要输出答案模 998244353998244353 的值。

输入格式

一行,两个正整数 HHWW

输出格式

一行,一个正整数表示答案。

样例 1

输入

3 2

输出

6

样例 2

输入

139 424

输出

148734121

样例 3

输入

12345 1234567890

输出

227996418

说明/提示

2H105,2W10102 \leq H \leq 10^5, 2 \leq W \leq 10^{10},满足 HHWW 都是整数。

样例解释

对于样例 11,以下六种摆放方式可以满足条件(用 # 来表示放置碎片,用 . 表示不放碎片):

#.   #.   .#   .#   ..   ..
.#   ..   #.   ..   #.   .#
..   .#   ..   #.   .#   #.