Знову запити?...
Всі учасники дуже втомилися від задач на запити, кожен контест повинен мати хоча б одну таку задачу. Ось і вона...
Вам дано масив цілих чисел довжини . Вам треба обробляти наступні запити:
l r x — присвоїти кожному елементу на відрізку значення , де — знак побітового
I
(AND
).? — вивести максимальне значення по всім парам та > 0. Якщо такої пари нема — виведіть .
У вхідних даних будуть лише запити першого типу. Вважайте, що після кожного запиту першого типу йде запит другого типу. Також до першого запита першого типу треба вивести відповідь на запит другого типу.
Через тут позначено найбільший спільний дільник чисел і . Наприклад, = , а = .
Input
Перший рядок містить два цілі числа () та () — кількість елементів масиву та кількість запитів першого типу.
Наступний рядок містить цілих чисел ( — елементи масиву.
Далі йдуть рядків, кожен з яких містить три цілі числа , та — опис запита.
Output
Виведіть рядок — відповіді на запити другого типу.
Examples
Note
Пояснення до першого прикладу:
До виконання операцій першого типу маємо масив , максимальне дорівнює = .
Після першої операції маємо масив , максимальне дорівнює = = = .
Після другої операції маємо масив , максимальне дорівнює = .
Scoring
Рішення, які правильно працюють для , набиратимуть принаймні балів.
Рішення, які правильно працюють для , набиратимуть принаймні балів.