Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

G. Magic multisets

time limit per test

4 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputIn the School of Magic in Dirtpolis a lot of interesting objects are studied on Computer Science lessons.

Consider, for example, the magic multiset. If you try to add an integer to it that is already presented in the multiset, each element in the multiset duplicates. For example, if you try to add the integer $$$2$$$ to the multiset $$$\{1, 2, 3, 3\}$$$, you will get $$$\{1, 1, 2, 2, 3, 3, 3, 3\}$$$.

If you try to add an integer that is not presented in the multiset, it is simply added to it. For example, if you try to add the integer $$$4$$$ to the multiset $$$\{1, 2, 3, 3\}$$$, you will get $$$\{1, 2, 3, 3, 4\}$$$.

Also consider an array of $$$n$$$ initially empty magic multisets, enumerated from $$$1$$$ to $$$n$$$.

You are to answer $$$q$$$ queries of the form "add an integer $$$x$$$ to all multisets with indices $$$l, l + 1, \ldots, r$$$" and "compute the sum of sizes of multisets with indices $$$l, l + 1, \ldots, r$$$". The answers for the second type queries can be large, so print the answers modulo $$$998244353$$$.

Input

The first line contains two integers $$$n$$$ and $$$q$$$ ($$$1 \leq n, q \leq 2 \cdot 10^{5}$$$) — the number of magic multisets in the array and the number of queries, respectively.

The next $$$q$$$ lines describe queries, one per line. Each line starts with an integer $$$t$$$ ($$$1 \leq t \leq 2$$$) — the type of the query. If $$$t$$$ equals $$$1$$$, it is followed by three integers $$$l$$$, $$$r$$$, $$$x$$$ ($$$1 \leq l \leq r \leq n$$$, $$$1 \leq x \leq n$$$) meaning that you should add $$$x$$$ to all multisets with indices from $$$l$$$ to $$$r$$$ inclusive. If $$$t$$$ equals $$$2$$$, it is followed by two integers $$$l$$$, $$$r$$$ ($$$1 \leq l \leq r \leq n$$$) meaning that you should compute the sum of sizes of all multisets with indices from $$$l$$$ to $$$r$$$ inclusive.

Output

For each query of the second type print the sum of sizes of multisets on the given segment.

The answers can be large, so print them modulo $$$998244353$$$.

Examples

Input

4 4

1 1 2 1

1 1 2 2

1 1 4 1

2 1 4

Output

10

Input

3 7

1 1 1 3

1 1 1 3

1 1 1 2

1 1 1 1

2 1 1

1 1 1 2

2 1 1

Output

4

8

Note

In the first example after the first two queries the multisets are equal to $$$[\{1, 2\},\{1, 2\},\{\},\{\}]$$$, after the third query they are equal to $$$[\{1, 1, 2, 2\},\{1, 1, 2, 2\},\{1\},\{1\}]$$$.

In the second example the first multiset evolves as follows:

$$$\{\} \to \{3\} \to \{3, 3\} \to \{2, 3, 3\} \to \{1, 2, 3, 3\} \to \{1, 1, 2, 2, 3, 3, 3, 3\}$$$.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Aug/21/2018 15:37:34 (f1).

Desktop version, switch to mobile version.

User lists

Name |
---|