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. Rock-Paper-Scissors Champion

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard output$$$n$$$ players are going to play a rock-paper-scissors tournament. As you probably know, in a one-on-one match of rock-paper-scissors, two players choose their shapes independently. The outcome is then determined depending on the chosen shapes: "paper" beats "rock", "rock" beats "scissors", "scissors" beat "paper", and two equal shapes result in a draw.

At the start of the tournament all players will stand in a row, with their numbers increasing from $$$1$$$ for the leftmost player, to $$$n$$$ for the rightmost player. Each player has a pre-chosen shape that they will use in every game throughout the tournament. Here's how the tournament is conducted:

- If there is only one player left, he is declared the champion.
- Otherwise, two adjacent players in the row are chosen arbitrarily, and they play the next match. The losing player is eliminated from the tournament and leaves his place in the row (with his former neighbours becoming adjacent). If the game is a draw, the losing player is determined by a coin toss.

The organizers are informed about all players' favoured shapes. They wish to find out the total number of players who have a chance of becoming the tournament champion (that is, there is a suitable way to choose the order of the games and manipulate the coin tosses). However, some players are still optimizing their strategy, and can inform the organizers about their new shapes. Can you find the number of possible champions after each such request?

Input

The first line contains two integers $$$n$$$ and $$$q$$$ — the number of players and requests respectively ($$$1 \leq n \leq 2 \cdot 10^5$$$, $$$0 \leq q \leq 2 \cdot 10^5$$$).

The second line contains a string of $$$n$$$ characters. The $$$i$$$-th of these characters is "R", "P", or "S" if the player $$$i$$$ was going to play "rock", "paper", or "scissors" before all requests respectively.

The following $$$q$$$ lines describe the requests. The $$$j$$$-th of these lines contain an integer $$$p_j$$$ and a character $$$c_j$$$ meaning that the player $$$p_j$$$ is going to use the shape described by the character $$$c_j$$$ from this moment ($$$1 \leq p_j \leq n$$$).

Output

Print $$$q + 1$$$ integers $$$r_0, \ldots, r_q$$$, where $$$r_k$$$ is the number of possible champions after processing $$$k$$$ requests.

Example

Input

3 5 RPS 1 S 2 R 3 P 1 P 2 P

Output

2 2 1 2 2 3

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Jan/18/2019 09:43:57 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|