P10274 [USACO24OPEN] Logical Moos B

Description

Farmer John has a boolean statement that is $N$ keywords long ($1 \leq N < 2 \cdot 10^5$, $N$ odd). Only $\texttt{true}$ or $\texttt{false}$ appear in odd positions, while only $\texttt{and}$ and $\texttt{or}$ appear in even positions. A phrase of the form $x\text{ OPERATOR }y$, where $x$ and $y$ are either $\texttt{true}$ or $\texttt{false}$, and $\text{OPERATOR}$ is $\texttt{and}$ or $\texttt{or}$, evaluates as follows: - $x\texttt{ and }y$: This evaluates to true if both $x$ and $y$ are true, and false otherwise. - $x\texttt{ or }y$: This evaluates to true if either $x$ or $y$ is true, and false otherwise. When evaluating the statement, FJ has to take the order of precedence in Moo Language into account. Similar to C++, $\texttt{and}$ takes priority over $\texttt{or}$. More specifically, to evaluate the statement, repeat the following step until the statement consists of only one keyword. 1. If the statement contains an $\texttt{and}$, choose any of them and replace the phrase surrounding it with its evaluation. 1. Otherwise, the statement contains an $\texttt{or}$. Choose any of them and replace the phrase surrounding it with its evaluation. It may be proven that if multiple phrases can be evaluated during a given step, it does not matter which one is chosen; the statement will always evaluate to the same value. FJ has $Q$ $(1 \leq Q \leq 2 \cdot 10^5)$ queries. In each query, he gives you two integers $l$ and $r$ ($1 \leq l \leq r \leq N$, $l$ and $r$ are both odd), and deletes the segment from keyword $l$ to keyword $r$ inclusive. In turn, he wishes to replace the segment he just deleted with just one simple $\texttt{true}$ or $\texttt{false}$ so that the whole statement evaluates to a certain boolean value. Help FJ determine if it's possible!

Input Format

The first line contains $N$ and $Q$. The next line contains $N$ strings, a valid boolean statement. The following $Q$ lines contain two integers $l$ and $r$, and a string $\texttt{true}$ or $\texttt{false}$, denoting whether he wants the whole statement to evaluate to true or false.

Output Format

Output a string of length $Q$, where the $i$'th character is Y if the $i$'th query is possible, otherwise N.

Explanation/Hint

##### For Sample 1: Let's analyze the first query: If we were to replace delete the segment $[1, 1]$ and replace it with $\texttt{true}$, then the whole statement becomes: ``` true and true or true ``` We evaluate the $\texttt{and}$ keyword from at position $2$ and obtain ``` true or true ``` Since we have no $\texttt{and}$ keywords left, we have to evaluate the $\texttt{or}$ keyword. After evaluation, all that is left is ``` true ``` It can be shown that if we were to replace the segment with $\texttt{false}$, the statement will still evaluate to $\texttt{true}$, so we output N since the statement cannot possibly evaluate to $\texttt{false}$. For the second query, we can replace the segment $[1, 3]$ with $\texttt{true}$ and the whole statement will evaluate to $\texttt{true}$, so we output Y. For the third query, since $[1, 5]$ is the whole statement, we can replace it with anything, so we output Y. #### SCORING: - Inputs 3-5: $N,Q\le 10^2$ - Inputs 6-8: $N,Q\le 10^3$ - Inputs 9-26: No additional constraints.