The fifth Lipetsk collegiate programming contest. Finals. 8-11 form
Statement is not available in English language
A. Долгая игра
ограничение по времени на тест
1 секунда
ограничение по памяти на тест
256 мегабайт
ввод
стандартный ввод
вывод
стандартный вывод

Леша очень любит играть с кубиками. Иногда он строит из них стены, иногда рисует на них буквы, а затем составляет слова, но сегодня особенный день, ведь к Леше в гости пришла Полина, поэтому Леша придумал новую игру.

Перед началом игры Леша достал из шкафа $$$N$$$ кубиков, после чего на каждом кубике написал число от $$$1$$$ до $$$N$$$. Разумеется, ни на каких двух кубиках Леша не написал одно и то же число.

После успешной подготовки к игре Леша надел на глаза повязку, благодаря которой он больше не видит кубики и числа, написанные на них. Далее Леша и Полина по очереди делают ходы, причем первым ходит Леша, ведь кубики принадлежат ему!

Своим первым ходом Леша случайно равновероятно перемешивает все лежащие перед ним кубики и выкладывает их в ряд. После этого Полина во время своего хода сообщает ему, какие кубики лежат на своем месте. Будем говорить, что кубик с написанным на нем числом $$$A$$$ лежит на своем месте, если слева от него находятся ровно $$$A - 1$$$ кубиков. Во время всех следующих ходов Леша не будет трогать кубики, которые лежат на своем месте.

Далее Леша снова перемешивает все кубики, которые лежат не на своих местах, а Полина сообщает ему, какие из них оказались на своем месте. Игра продолжается до тех пор, пока все кубики не окажутся на своих местах.

Перед началом игры Леше стало интересно, насколько много ходов ему придется сделать. Посчитайте математическое ожидание количества ходов Леши, с учетом первого хода.

Входные данные

В единственной строке записано целое число $$$N$$$ ($$$1 \leq N \leq 10^6$$$) — количество кубиков, которые есть у Леши.

Выходные данные

Нетрудно показать, что ответ можно представить в виде несократимой дроби $$$\frac{P}{Q}$$$.

В качестве ответа выведите $$$P \cdot Q^{-1} \pmod{998\,244\,353}$$$.

Примеры
Входные данные
1
Выходные данные
1
Входные данные
2
Выходные данные
2
Примечание

В первом примере у Леши есть всего один кубик, который после его первого хода с вероятностью $$$1$$$ окажется на своем месте. Значит, математическое ожидание количества ходов Леши равно $$$1$$$.

Во втором примере у Леши есть два кубика. С вероятностью $$$\frac{1}{2}$$$ после первого же хода они оба окажутся на своих местах и игра закончится, и с вероятностью $$$\frac{1}{2}$$$ ни один из кубиков не окажется на своем месте, и Леша окажется в том же положении, что и в начале игры. Тогда можно понять, что вероятность того, что игра закончится ровно через $$$k$$$ ходов, равна $$$\frac{1}{2^{k}}$$$. Можно показать, что математическое ожидание этой случайной величины равно 2.

Напомним, что математическое ожидание случайной величины $$$X$$$ равно $$$$$$\sum \limits_i x_i \cdot P(X = x_i)$$$$$$

Здесь $$$P(X = x_i)$$$ — вероятность того, что значение случайной величины равно $$$x_i$$$, а $$$x_i$$$ — все возможные значения случайной величины.

Также напомним, что $$$Q \cdot Q^{-1} \equiv 1 \pmod{998\,244\,353}$$$.

Statement is not available in English language
Statement is not available in English language
D. Young Explorers
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Young wilderness explorers set off to their first expedition led by senior explorer Russell. Explorers went into a forest, set up a camp and decided to split into groups to explore as much interesting locations as possible. Russell was trying to form groups, but ran into some difficulties...

Most of the young explorers are inexperienced, and sending them alone would be a mistake. Even Russell himself became senior explorer not long ago. Each of young explorers has a positive integer parameter $$$e_i$$$ — his inexperience. Russell decided that an explorer with inexperience $$$e$$$ can only join the group of $$$e$$$ or more people.

Now Russell needs to figure out how many groups he can organize. It's not necessary to include every explorer in one of the groups: some can stay in the camp. Russell is worried about this expedition, so he asked you to help him.

Input

The first line contains the number of independent test cases $$$T$$$($$$1 \leq T \leq 2 \cdot 10^5$$$). Next $$$2T$$$ lines contain description of test cases.

The first line of description of each test case contains the number of young explorers $$$N$$$ ($$$1 \leq N \leq 2 \cdot 10^5$$$).

The second line contains $$$N$$$ integers $$$e_1, e_2, \ldots, e_N$$$ ($$$1 \leq e_i \leq N$$$), where $$$e_i$$$ is the inexperience of the $$$i$$$-th explorer.

It's guaranteed that sum of all $$$N$$$ doesn't exceed $$$3 \cdot 10^5$$$.

Output

Print $$$T$$$ numbers, each number on a separate line.

In $$$i$$$-th line print the maximum number of groups Russell can form in $$$i$$$-th test case.

Example
Input
2
3
1 1 1
5
2 3 1 2 2
Output
3
2
Note

In the first example we can organize three groups. There will be only one explorer in each group. It's correct because inexperience of each explorer equals to $$$1$$$, so it's not less than the size of his group.

In the second example we can organize two groups. Explorers with inexperience $$$1$$$, $$$2$$$ and $$$3$$$ will form the first group, and the other two explorers with inexperience equal to $$$2$$$ will form the second group.

This solution is not unique. For example, we can form the first group using the three explorers with inexperience equal to $$$2$$$, and the second group using only one explorer with inexperience equal to $$$1$$$. In this case the young explorer with inexperience equal to $$$3$$$ will not be included in any group.

Statement is not available in English language
E. M — многомерность
ограничение по времени на тест
1 секунда
ограничение по памяти на тест
256 мегабайт
ввод
стандартный ввод
вывод
стандартный вывод

Многие в детстве играют с кубиками, затем все в школе изучают геометрию и встречаются с такими простыми объектами, как параллелепипеды. Но ведь изучать геометрию в трехмерном пространстве — это так скучно! Даже четырехмерным пространством уже никого не удивишь! Поэтому в этой задаче мы предлагаем вам изучить параллелепипеды в $$$M$$$-мерном пространстве. Чувствуете, как интересно?

Определим $$$M$$$-мерный параллелепипед как набор отрезков $$$[a_1, b_1], [a_2, b_2], \ldots, [a_M, b_M]$$$, где $$$a_i \lt b_i$$$ для всех $$$i = 1 \ldots M$$$. Для простоты будем считать, что все $$$a_i$$$ и $$$b_i$$$ являются целыми.

Скажем, что точка с координатами $$$(x_1, x_2, \ldots, x_M)$$$ лежит внутри параллелепипеда, если выполнены неравенства:

$$$a_1 \leq x_1 \leq b_1,$$$ $$$a_2 \leq x_2 \leq b_2,$$$ $$$\dots$$$ $$$a_M \leq x_M \leq b_M.$$$

Вам даны $$$N$$$ $$$M$$$-мерных параллелепипедов. Требуется посчитать, сколько точек с целочисленными координатами лежат внутри ровно $$$N-1$$$ параллелепипеда. Так как ответ может быть большим, выведите остаток от деления количества точек на число $$$998\,244\,353$$$.

Входные данные

В первой строке записаны два числа $$$N$$$ и $$$M$$$ ($$$2 \leq N \leq 2 \cdot 10^5, 1 \leq M \leq 2 \cdot 10^5, 2 \leq N \cdot M \leq 2 \cdot 10^5$$$) — количество параллелепипедов и размерность пространства соответственно.

Каждая из следующих $$$N$$$ строк задает параллелепипед. В каждой строке через пробел записаны $$$2 \cdot M$$$ чисел в следующем порядке: $$$a_1, b_1, a_2, b_2, \ldots, a_M, b_M$$$ ($$$-10^6 \leq a_i \lt b_i \leq 10^6$$$ для всех $$$i$$$).

Выходные данные

Выведите одно число — остаток от деления количества точек, лежащих внутри ровно $$$N-1$$$ параллелепипеда, на число $$$998\,244\,353$$$.

Примеры
Входные данные
2 2
2 4 1 5
1 4 4 6
Выходные данные
15
Входные данные
4 1
1 6
2 4
6 7
2 9
Выходные данные
4
Примечание

Рисунок к первому примеру, в котором даны два прямоугольника. Необходимо посчитать все целочисленные точки, которые лежат внутри (или на границе) ровно одного прямоугольника. В данном примере таких точек 15. Все эти точки отмечены на рисунке.

Во втором примере $$$M=1$$$, значит параллелепипеды являются обыкновенными отрезками на прямой.

F. Game With Array
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Petya and Vasya are competing with each other in a new interesting game as they always do.

At the beginning of the game Petya has to come up with an array of $$$N$$$ positive integers. Sum of all elements in his array should be equal to $$$S$$$. Then Petya has to select an integer $$$K$$$ such that $$$0 \leq K \leq S$$$.

In order to win, Vasya has to find a non-empty subarray in Petya's array such that the sum of all selected elements equals to either $$$K$$$ or $$$S - K$$$. Otherwise Vasya loses.

You are given integers $$$N$$$ and $$$S$$$. You should determine if Petya can win, considering Vasya plays optimally. If Petya can win, help him to do that.

Input

The first line contains two integers $$$N$$$ and $$$S$$$ ($$$1 \leq N \leq S \leq 10^{6}$$$) — the required length of the array and the required sum of its elements.

Output

If Petya can win, print "YES" (without quotes) in the first line. Then print Petya's array in the second line. The array should contain $$$N$$$ positive integers with sum equal to $$$S$$$. In the third line print $$$K$$$. If there are many correct answers, you can print any of them.

If Petya can't win, print "NO" (without quotes).

You can print each letter in any register (lowercase or uppercase).

Examples
Input
1 4
Output
YES
4
2
Input
3 4
Output
NO
Input
3 8
Output
YES
2 1 5
4

G. Sequence with Digits
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Let's define the following recurrence: $$$$$$a_{n+1} = a_{n} + minDigit(a_{n}) \cdot maxDigit(a_{n}).$$$$$$

Here $$$minDigit(x)$$$ and $$$maxDigit(x)$$$ are the minimal and maximal digits in the decimal representation of $$$x$$$ without leading zeroes. For examples refer to notes.

Your task is calculate $$$a_{K}$$$ for given $$$a_{1}$$$ and $$$K$$$.

Input

The first line contains one integer $$$t$$$ ($$$1 \le t \le 1000$$$) — the number of independent test cases.

Each test case consists of a single line containing two integers $$$a_{1}$$$ and $$$K$$$ ($$$1 \le a_{1} \le 10^{18}$$$, $$$1 \le K \le 10^{16}$$$) separated by a space.

Output

For each test case print one integer $$$a_{K}$$$ on a separate line.

Example
Input
8
1 4
487 1
487 2
487 3
487 4
487 5
487 6
487 7
Output
42
487
519
528
544
564
588
628
Note

$$$a_{1} = 487$$$

$$$a_{2} = a_{1} + minDigit(a_{1}) \cdot maxDigit(a_{1}) = 487 + \min (4, 8, 7) \cdot \max (4, 8, 7) = 487 + 4 \cdot 8 = 519$$$

$$$a_{3} = a_{2} + minDigit(a_{2}) \cdot maxDigit(a_{2}) = 519 + \min (5, 1, 9) \cdot \max (5, 1, 9) = 519 + 1 \cdot 9 = 528$$$

$$$a_{4} = a_{3} + minDigit(a_{3}) \cdot maxDigit(a_{3}) = 528 + \min (5, 2, 8) \cdot \max (5, 2, 8) = 528 + 2 \cdot 8 = 544$$$

$$$a_{5} = a_{4} + minDigit(a_{4}) \cdot maxDigit(a_{4}) = 544 + \min (5, 4, 4) \cdot \max (5, 4, 4) = 544 + 4 \cdot 5 = 564$$$

$$$a_{6} = a_{5} + minDigit(a_{5}) \cdot maxDigit(a_{5}) = 564 + \min (5, 6, 4) \cdot \max (5, 6, 4) = 564 + 4 \cdot 6 = 588$$$

$$$a_{7} = a_{6} + minDigit(a_{6}) \cdot maxDigit(a_{6}) = 588 + \min (5, 8, 8) \cdot \max (5, 8, 8) = 588 + 5 \cdot 8 = 628$$$

Statement is not available in English language
H. Карантин
ограничение по времени на тест
1 секунда
ограничение по памяти на тест
256 мегабайт
ввод
стандартный ввод
вывод
стандартный вывод

Вокруг живописного круглого озера расположено $$$N$$$ домов на одинаковом расстоянии $$$D$$$ друг от друга. Михаил живет в одном из этих домов, во всех остальных домах живут его друзья. Все нравится Михаилу: и прекрасная природа, и добрые соседи, и мягкий климат, но и в эти места добрался коронавирус... И вот теперь жители самоизолировались, и могут выходить на прогулку только по одному человеку, при этом все остальные находятся в своих домах.

Михаил хочет во время своей прогулки пройти мимо каждого дома, чтобы оставить в почтовом ящике каждого из домов письмо-приветствие своим друзьям. При этом перемещаться между домами он будет по кратчайшему пути. Изначально Михаил выбирает некоторый порядок, в котором он будет посещать дома друзей, после чего начинает свою прогулку. Оставив письмо в почтовом ящике одного дома, он перемещается к другому дому, и так до тех пор, пока не пройдет все дома, после чего зайдет в гости к другу, который живет в последнем посещенном доме.

Михаил, пользуясь возможностью прогуляться, хочет пройти во время своей прогулки как можно большее расстояние. Это расстояние ему нужно сообщить для получения пропуска на выход из дома. В таком важном деле ошибаться Михаилу нельзя. Помогите Михаилу верно вычислить максимальное расстояние, которое он может пройти во время прогулки.

Входные данные

В единственной строке через пробел записаны два числа: $$$N$$$ и $$$D$$$ ($$$3 \leq N \leq 10^6, 1 \leq D \leq 10^6$$$) — количество домов и расстояние между соседними домами соответственно.

Выходные данные

Выведите одно число — максимальное расстояние, которое сможет пройти Михаил во время прогулки.

Примеры
Входные данные
3 5
Выходные данные
10
Входные данные
6 10
Выходные данные
130

I. Count Triangles
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

Like any unknown mathematician, Yuri has favourite numbers: $$$A$$$, $$$B$$$, $$$C$$$, and $$$D$$$, where $$$A \leq B \leq C \leq D$$$. Yuri also likes triangles and once he thought: how many non-degenerate triangles with integer sides $$$x$$$, $$$y$$$, and $$$z$$$ exist, such that $$$A \leq x \leq B \leq y \leq C \leq z \leq D$$$ holds?

Yuri is preparing problems for a new contest now, so he is very busy. That's why he asked you to calculate the number of triangles with described property.

The triangle is called non-degenerate if and only if its vertices are not collinear.

Input

The first line contains four integers: $$$A$$$, $$$B$$$, $$$C$$$ and $$$D$$$ ($$$1 \leq A \leq B \leq C \leq D \leq 5 \cdot 10^5$$$) — Yuri's favourite numbers.

Output

Print the number of non-degenerate triangles with integer sides $$$x$$$, $$$y$$$, and $$$z$$$ such that the inequality $$$A \leq x \leq B \leq y \leq C \leq z \leq D$$$ holds.

Examples
Input
1 2 3 4
Output
4
Input
1 2 2 5
Output
3
Input
500000 500000 500000 500000
Output
1
Note

In the first example Yuri can make up triangles with sides $$$(1, 3, 3)$$$, $$$(2, 2, 3)$$$, $$$(2, 3, 3)$$$ and $$$(2, 3, 4)$$$.

In the second example Yuri can make up triangles with sides $$$(1, 2, 2)$$$, $$$(2, 2, 2)$$$ and $$$(2, 2, 3)$$$.

In the third example Yuri can make up only one equilateral triangle with sides equal to $$$5 \cdot 10^5$$$.

J. Restorer Distance
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

You have to restore the wall. The wall consists of $$$N$$$ pillars of bricks, the height of the $$$i$$$-th pillar is initially equal to $$$h_{i}$$$, the height is measured in number of bricks. After the restoration all the $$$N$$$ pillars should have equal heights.

You are allowed the following operations:

  • put a brick on top of one pillar, the cost of this operation is $$$A$$$;
  • remove a brick from the top of one non-empty pillar, the cost of this operation is $$$R$$$;
  • move a brick from the top of one non-empty pillar to the top of another pillar, the cost of this operation is $$$M$$$.

You cannot create additional pillars or ignore some of pre-existing pillars even if their height becomes $$$0$$$.

What is the minimal total cost of restoration, in other words, what is the minimal total cost to make all the pillars of equal height?

Input

The first line of input contains four integers $$$N$$$, $$$A$$$, $$$R$$$, $$$M$$$ ($$$1 \le N \le 10^{5}$$$, $$$0 \le A, R, M \le 10^{4}$$$) — the number of pillars and the costs of operations.

The second line contains $$$N$$$ integers $$$h_{i}$$$ ($$$0 \le h_{i} \le 10^{9}$$$) — initial heights of pillars.

Output

Print one integer — the minimal cost of restoration.

Examples
Input
3 1 100 100
1 3 8
Output
12
Input
3 100 1 100
1 3 8
Output
9
Input
3 100 100 1
1 3 8
Output
4
Input
5 1 2 4
5 5 3 6 5
Output
4
Input
5 1 2 2
5 5 3 6 5
Output
3

K. Guess Divisors Count
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

This is an interactive problem.

We have hidden an integer $$$1 \le X \le 10^{9}$$$. You don't have to guess this number. You have to find the number of divisors of this number, and you don't even have to find the exact number: your answer will be considered correct if its absolute error is not greater than 7 or its relative error is not greater than $$$0.5$$$. More formally, let your answer be $$$ans$$$ and the number of divisors of $$$X$$$ be $$$d$$$, then your answer will be considered correct if at least one of the two following conditions is true:

  • $$$| ans - d | \le 7$$$
  • $$$\frac{1}{2} \le \frac{ans}{d} \le 2$$$

You can make at most 22 queries. One query consist of one integer $$$1 \le Q \le 10^{18}$$$. In response you will get $$$gcd(X, Q)$$$ — the greatest common divisor of $$$X$$$ and $$$Q$$$.

The number $$$X$$$ is fixed before all queries. In other words, interactor is not adaptive.

Let's call the process of guessing the number of divisors of number $$$X$$$ a game. In one test you will have to play $$$T$$$ independent games, that is, guess the number of divisors $$$T$$$ times for $$$T$$$ independent values of $$$X$$$.

Input

The first line of input contains one integer $$$T$$$ ($$$1 \le T \le 100$$$) — the number of games.

Interaction

To make a query print a line "? Q" ($$$1 \le Q \le 10^{18}$$$). After that read one integer $$$gcd(X, Q)$$$. You can make no more than 22 such queries during one game.

If you are confident that you have figured out the number of divisors of $$$X$$$ with enough precision, you can print your answer in "! ans" format. $$$ans$$$ have to be an integer. If this was the last game, you have to terminate the program, otherwise you have to start the next game immediately. Note that interactor doesn't print anything in response to you printing answer.

After printing a query do not forget to output end of line and flush the output. To do this, use:

  • fflush(stdout) or cout.flush() in C++;
  • System.out.flush() in Java;
  • flush(output) in Pascal;
  • stdout.flush() in Python;
  • see documentation for other languages.
Example
Input
2

1

1

1


1024

1048576

4194304
Output

? 982306799268821872

? 230856864650023977

? 134690134760714371

! 5
? 1024

? 1048576

? 1073741824

! 42
Note

Why the limitation for number of queries is 22 exactly? Maybe the problem author is a Taylor Swift fan.

Let's look at the example.

In the first game $$$X = 998\,244\,353$$$ is hidden. Would be hard to guess this, right? This number is prime, so the number of its divisors is 2. The solution has made several random queries, and all the responses turned out to be 1 (strange things, not even one of three random numbers is divisible by $$$998\,244\,353$$$). It's fare to assume that the hidden number doesn't have many divisors, so the solution has answered 5. Why not. This answer will be considered correct since $$$| 5 - 2 | = 3 \le 7$$$.

In the second game $$$X = 4\,194\,304 = 2^{22}$$$ is hidden, it has 23 divisors. The solution has made queries $$$1024 = 2^{10}$$$, $$$1\,048\,576 =2^{20}$$$, $$$1\,073\,741\,824 = 2^{30}$$$ and got responses $$$1024 = 2^{10}$$$, $$$1\,048\,576 =2^{20}$$$, $$$4\,194\,304 = 2^{22}$$$, respectively. Then the solution got completely confused and answered the answer to The Ultimate Question of Life, the Universe, and Everything. This answer will be considered correct since $$$\frac{1}{2} \le \frac{42}{23} \le 2$$$.

Statement is not available in English language
L. Стековая машина
ограничение по времени на тест
1 секунда
ограничение по памяти на тест
256 мегабайт
ввод
стандартный ввод
вывод
стандартный вывод

Дано $$$0 \le N \le 100$$$ целых неотрицательных чисел, выведите их сумму.

Эх, как было бы хорошо, если бы вам нужно было написать программу для решения такой задачи на C++ или Python...

У вас есть машина, память которой — это стек, элементы которого являются целыми числами. Количество элементов стека в данный момент мы будем обозначать как $$$sz$$$.

Напомним, что стек — это абстрактная структура данных, хранящая коллекцию элементов, и работающая по принципу LIFO (последним пришёл — первым вышел). Стек поддерживает две базовые операции: положить элемент на вершину стека, взять элемент с вершины стека. В качестве аналогии можно представить стопку тарелок: вы не можете оперировать с тарелками не на вершине стопки.

Список доступных инструкций приведен ниже. RTE (Run-Time Error) обозначает, что выполнение программы завершилось с ошибкой, вам следует избегать таких ситуаций.

  • PUSHZ — положить на стек 0;
  • POP — взять со стека $$$x$$$ (если $$$sz \lt 1$$$, то RTE);
  • SWAP2 — взять со стека $$$x$$$, взять со стека $$$y$$$, положить на стек $$$x$$$, положить на стек $$$y$$$ (если $$$sz \lt 2$$$, то RTE);
  • SWAP3 — взять со стека $$$x$$$, взять со стека $$$y$$$, взять со стека $$$z$$$, положить на стек $$$y$$$, положить на стек $$$x$$$, положить на стек $$$z$$$ (если $$$sz \lt 3$$$, то RTE);
  • COPY — взять со стека $$$x$$$, положить на стек $$$x$$$, положить на стек $$$x$$$ (если $$$sz \lt 1$$$, то RTE);
  • INC — взять со стека $$$x$$$, положить на стек $$$x+1$$$ (если $$$sz \lt 1$$$, то RTE);
  • DEC — взять со стека $$$x$$$, положить на стек $$$x-1$$$ (если $$$sz \lt 1$$$, то RTE);
  • ADD — взять со стека $$$x$$$, взять со стека $$$y$$$, положить на стек $$$x+y$$$ (если $$$sz \lt 2$$$, то RTE);
  • SUB — взять со стека $$$x$$$, взять со стека $$$y$$$, положить на стек $$$x-y$$$ (если $$$sz \lt 2$$$, то RTE);

Также доступны условный оператор и цикл while. Чтобы их использовать, сначала нужно научиться задавать какие-то условия:

  • EZ — TRUE если на вершине стека 0 (если $$$sz \lt 1$$$, то RTE);
  • GZ — TRUE если на вершине стека положительное число (если $$$sz \lt 1$$$, то RTE);
  • HAVE1, HAVE2 — TRUE если $$$sz \ge k$$$ (обратите внимание, что $$$k \in \{ 1, 2 \}$$$, HAVE3 не является условием)

К любому условию можно добавить NOT в начале, например NOT GZ (обратите внимание на пробел) TRUE если на вершине стека 0 или отрицательное число.

Условный оператор:

IF cond THEN
BEGIN
body
END

Цикл while:

WHILE cond DO
BEGIN
body
END

В обоих случаях cond — одно из условий, описанных выше, body — тело условного оператора или цикла — последовательность команд, которые будут выполнены, если cond=TRUE (один раз в случае условного оператора, или много раз в случае цикла). Циклы и условные операторы могут быть вложенными.

Вы должны написать программу для этой машины, котора решает следующую задачу:

Изначально стек был пуст. Числа $$$N, a_{1}, a_{2}, \ldots, a_{N}$$$ положили на стек в таком порядке (наверху стека лежит $$$a_{N}$$$, $$$N$$$ лежит в самом низу). После выполнения программы на вершине стека должно лежать число $$$a_{1} + a_{2} + \ldots + a_{N}$$$ (также в стеке могут лежать другие числа).

Гарантируется, что $$$0 \le N \le 100$$$, $$$0 \le a_{i}$$$. Каждая инструкция (а также проверки условия для условного оператора и цикла) выполняется 1 такт. Выполнение программы должно занимать не более $$$(N+22)^{2}$$$ тактов. В процессе выполнения программы не должно происходить RTE.

Входные данные

В этой задаче нет входных данных.

Выходные данные

Выведите программу для стековой машины, решающую описанную задачу.

Вы не обязаны использовать отступы. Любой пробельный символ может быть заменён на любое ненулевое количество пробельных символов, вставлять пробельные символы внутрь инструкций нельзя.

Все инструкции должны быть записаны именно так, как они записаны в тексте условия.

Пример
Входные данные

Выходные данные
PUSHZ
SWAP2
WHILE NOT EZ DO
BEGIN
    COPY
    SWAP3
    ADD
    SWAP2
    DEC
END
POP


WHILE NOT EZ DO
BEGIN
    COPY
    DEC
END
WHILE HAVE2 DO
BEGIN
    ADD
END
Примечание

Ответ на пример из условия содержит две программы, которые вычисляют сумму чисел от 1 до $$$N$$$ для $$$N \ge 0$$$.

В стеке могут храниться числа произвольного размера. И ваша программа должна работать для $$$a_{i}$$$ произвольного размера.

Намеренные попытки дестабилизировать работу проверяющей системы могут повлечь дисквалификацию команды. Жюри оставляет за собой право решать, что является невинной ошибкой, а что — намеренной попыткой дестабилизировать работу проверяющей системы.