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

D. Giving Awards

time limit per test

1 secondmemory limit per test

256 megabytesinput

standard inputoutput

standard outputThe employees of the R1 company often spend time together: they watch football, they go camping, they solve contests. So, it's no big deal that sometimes someone pays for someone else.

Today is the day of giving out money rewards. The R1 company CEO will invite employees into his office one by one, rewarding each one for the hard work this month. The CEO knows who owes money to whom. And he also understands that if he invites person *x* to his office for a reward, and then immediately invite person *y*, who has lent some money to person *x*, then they can meet. Of course, in such a situation, the joy of person *x* from his brand new money reward will be much less. Therefore, the R1 CEO decided to invite the staff in such an order that the described situation will not happen for any pair of employees invited one after another.

However, there are a lot of employees in the company, and the CEO doesn't have a lot of time. Therefore, the task has been assigned to you. Given the debt relationships between all the employees, determine in which order they should be invited to the office of the R1 company CEO, or determine that the described order does not exist.

Input

The first line contains space-separated integers *n* and *m* — the number of employees in R1 and the number of debt relations. Each of the following *m* lines contains two space-separated integers *a*_{i}, *b*_{i} (1 ≤ *a*_{i}, *b*_{i} ≤ *n*; *a*_{i} ≠ *b*_{i}), these integers indicate that the person number *a*_{i} owes money to a person a number *b*_{i}. Assume that all the employees are numbered from 1 to *n*.

It is guaranteed that each pair of people *p*, *q* is mentioned in the input data at most once. In particular, the input data will not contain pairs *p*, *q* and *q*, *p* simultaneously.

Output

Print -1 if the described order does not exist. Otherwise, print the permutation of *n* distinct integers. The first number should denote the number of the person who goes to the CEO office first, the second number denote the person who goes second and so on.

If there are multiple correct orders, you are allowed to print any of them.

Examples

Input

2 1

1 2

Output

2 1

Input

3 3

1 2

2 3

3 1

Output

2 1 3

Codeforces (c) Copyright 2010-2017 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Mar/28/2017 15:00:59 (c4).

Desktop version, switch to mobile version.
User lists

Name |
---|