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. Mages and Monsters

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputVova plays a computer game known as Mages and Monsters. Vova's character is a mage. Though as he has just started, his character knows no spells.

Vova's character can learn new spells during the game. Every spell is characterized by two values *x*_{i} and *y*_{i} — damage per second and mana cost per second, respectively. Vova doesn't have to use a spell for an integer amount of seconds. More formally, if he uses a spell with damage *x* and mana cost *y* for *z* seconds, then he will deal *x*·*z* damage and spend *y*·*z* mana (no rounding). If there is no mana left (mana amount is set in the start of the game and it remains the same at the beginning of every fight), then character won't be able to use any spells. It is prohibited to use multiple spells simultaneously.

Also Vova can fight monsters. Every monster is characterized by two values *t*_{j} and *h*_{j} — monster kills Vova's character in *t*_{j} seconds and has *h*_{j} health points. Mana refills after every fight (or Vova's character revives with full mana reserve), so previous fights have no influence on further ones.

Vova's character kills a monster, if he deals *h*_{j} damage to it in no more than *t*_{j} seconds using his spells (it is allowed to use more than one spell in a fight) and spending no more mana than he had at the beginning of the fight. If monster's health becomes zero exactly in *t*_{j} seconds (it means that the monster and Vova's character kill each other at the same time), then Vova wins the fight.

You have to write a program which can answer two types of queries:

- 1
*x**y*— Vova's character learns new spell which deals*x*damage per second and costs*y*mana per second. - 2
*t**h*— Vova fights the monster which kills his character in*t*seconds and has*h*health points.

Note that queries are given in a different form. Also remember that Vova's character knows no spells at the beginning of the game.

For every query of second type you have to determine if Vova is able to win the fight with corresponding monster.

Input

The first line contains two integer numbers *q* and *m* (2 ≤ *q* ≤ 10^{5}, 1 ≤ *m* ≤ 10^{12}) — the number of queries and the amount of mana at the beginning of every fight.

*i*-th of each next *q* lines contains three numbers *k*_{i}, *a*_{i} and *b*_{i} (1 ≤ *k*_{i} ≤ 2, 1 ≤ *a*_{i}, *b*_{i} ≤ 10^{6}).

Using them you can restore queries this way: let *j* be the index of the last query of second type with positive answer (*j* = 0 if there were none of these).

- If
*k*_{i}= 1, then character learns spell with*x*= (*a*_{i}+*j*)*mod*10^{6}+ 1,*y*= (*b*_{i}+*j*)*mod*10^{6}+ 1. - If
*k*_{i}= 2, then you have to determine if Vova is able to win the fight against monster with*t*= (*a*_{i}+*j*)*mod*10^{6}+ 1,*h*= (*b*_{i}+*j*)*mod*10^{6}+ 1.

Output

For every query of second type print YES if Vova is able to win the fight with corresponding monster and NO otherwise.

Example

Input

3 100

1 4 9

2 19 49

2 19 49

Output

YES

NO

Note

In first example Vova's character at first learns the spell with 5 damage and 10 mana cost per second. Next query is a fight with monster which can kill character in 20 seconds and has 50 health points. Vova kills it in 10 seconds (spending 100 mana). Next monster has 52 health, so Vova can't deal that much damage with only 100 mana.

Codeforces (c) Copyright 2010-2018 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Dec/16/2018 05:44:30 (f2).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|