Sort

Mirko is a great code breaker. He knows any cipher in the world can be broken by frequency analysis. He has completely the wrong idea what frequency analysis is, however.

He intercepted an enemy message. The message consists of $N$ numbers, smaller than or equal to $C$. Mirko belives freqency analysis consists of sorting this sequence so that more frequent numbers appear before less frequent ones.

Formally, the sequence must be sorted so that given any two
numbers $X$ and
$Y$, $X$ appears before $Y$ if the number of times
$X$ appears in the
original sequence is larger than the number of time
$Y$ does. If the number of
appearances is equal, the number whose *value* appears
sooner in the input should appear sooner in the sorted
sequence.

Help Mirko by creating a “frequency sorter”.

First line of input contains two integers, $N$ ($1 \le N \le 1\, 000$), the length of the message, and $C$ ($1 \le C \le 1\, 000\, 000\, 000$), the number from the task description above.

The next line contains $N$ positive integers smaller than or equal to $C$, the message itself.

The first and only line of output should contain $N$ numbers, the sorted sequence.

Sample Input 1 | Sample Output 1 |
---|---|

5 2 2 1 2 1 2 |
2 2 2 1 1 |

Sample Input 2 | Sample Output 2 |
---|---|

9 3 1 3 3 3 2 2 2 1 1 |
1 1 1 3 3 3 2 2 2 |

Sample Input 3 | Sample Output 3 |
---|---|

9 77 11 33 11 77 54 11 25 25 33 |
11 11 11 33 33 25 25 77 54 |