Problem A
Supercomputer
Jóhann, Marteinn and Símon have decided to make the next generation of supercomputers! They know that it probably won’t be long before Quantum computers take over, but since they don’t know anything about Quantum mechanics, they want to rush these new supercomputers out into the market, make their money, and hopefully retire with their wealth.
Since they’re trying to sell these things, they decide they need some cool features to promote the computers. Marteinn suggests painting flames on the back of the computers to make it look like they’re computing faster. Jóhann agrees, but suggests also adding a second keyboard so people can type faster, just like in that TV show: NCIS. Símon also agrees, but he thinks there’s something missing. What are they forgetting? Ah, of course, faster memory!
They decide to add an
-
given an integer
, flip the :th bit of the memory (changing a to a , and a to a ), and -
given integers
and , count how many bits between the :th bit and the :th bit are set to .
After announcing their new supercomputer with these three awesome features, they immediately received a large amount of orders. Of course everyone wants a supercomputer with flames painted on the back! But now it’s time to actually implement these features. While Jóhann, Marteinn and Símon are busy painting the computers and supplying more keyboards, they’ve hired you to implement their memory.
Input
The input consists of:
-
one line containing two integers
( ), the number of bits in the memory, and ( ), the number of queries; -
lines each of the form:-
F
( ) representing a query to flip the :th bit in memory; -
C
( ) representing a query to count the number of bits in the range from to , inclusive.
-
All
Output
For each query of the second type, output a single line
containing the number of bits set to
Sample Input 1 | Sample Output 1 |
---|---|
6 7 F 3 C 2 5 F 3 F 4 F 5 C 2 5 C 1 4 |
1 2 1 |