Please subscribe to the official Codeforces channel in Telegram via the link: https://t.me/codeforces_official.
×

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

F. Leha and security system

time limit per test

2 secondsmemory limit per test

512 megabytesinput

standard inputoutput

standard outputBankopolis, the city you already know, finally got a new bank opened! Unfortunately, its security system is not yet working fine... Meanwhile hacker Leha arrived in Bankopolis and decided to test the system!

Bank has *n* cells for clients' money. A sequence from *n* numbers *a*_{1}, *a*_{2}, ..., *a*_{n} describes the amount of money each client has. Leha wants to make requests to the database of the bank, finding out the total amount of money on some subsegments of the sequence and changing values of the sequence on some subsegments. Using a bug in the system, Leha can requests two types of queries to the database:

- 1 l r x y denoting that Leha changes each digit
*x*to digit*y*in each element of sequence*a*_{i}, for which*l*≤*i*≤*r*is holds. For example, if we change in number 11984381 digit 8 to 4, we get 11944341. It's worth noting that Leha, in order to stay in the shadow, never changes digits in the database to 0, i.e.*y*≠ 0. - 2 l r denoting that Leha asks to calculate and print the sum of such elements of sequence
*a*_{i}, for which*l*≤*i*≤*r*holds.

As Leha is a white-hat hacker, he don't want to test this vulnerability on a real database. You are to write a similar database for Leha to test.

Input

The first line of input contains two integers *n* and *q* (1 ≤ *n* ≤ 10^{5}, 1 ≤ *q* ≤ 10^{5}) denoting amount of cells in the bank and total amount of queries respectively.

The following line contains *n* integers *a*_{1}, *a*_{2}, ..., *a*_{n} (1 ≤ *a*_{i} < 10^{9}) denoting the amount of money in each cell initially. These integers do not contain leading zeros.

Each of the following *q* lines has one of the formats:

- 1 l r x y (1 ≤
*l*≤*r*≤*n*, 0 ≤*x*≤ 9, 1 ≤*y*≤ 9), denoting Leha asks to change each digit*x*on digit*y*for each element*a*_{i}of the sequence for which*l*≤*i*≤*r*holds; - 2 l r (1 ≤
*l*≤*r*≤*n*), denoting you have to calculate and print the sum of elements*a*_{i}for which*l*≤*i*≤*r*holds.

Output

For each second type query print a single number denoting the required sum.

Examples

Input

5 5

38 43 4 12 70

1 1 3 4 8

2 2 4

1 4 5 0 8

1 2 5 8 7

2 1 5

Output

103

207

Input

5 5

25 36 39 40 899

1 1 3 2 7

2 1 2

1 3 5 9 1

1 4 4 0 9

2 1 5

Output

111

1002

Note

Let's look at the example testcase.

Initially the sequence is [38, 43, 4, 12, 70].

After the first change each digit equal to 4 becomes 8 for each element with index in interval [1; 3]. Thus, the new sequence is [38, 83, 8, 12, 70].

The answer for the first sum's query is the sum in the interval [2; 4], which equal 83 + 8 + 12 = 103, so the answer to this query is 103.

The sequence becomes [38, 83, 8, 12, 78] after the second change and [38, 73, 7, 12, 77] after the third.

The answer for the second sum's query is 38 + 73 + 7 + 12 + 77 = 207.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/10/2018 02:09:39 (d1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|