CF29E.Quarrel

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

Friends Alex and Bob live in Bertown. In this town there are nn crossroads, some of them are connected by bidirectional roads of equal length. Bob lives in a house at the crossroads number 11 , Alex — in a house at the crossroads number nn .

One day Alex and Bob had a big quarrel, and they refused to see each other. It occurred that today Bob needs to get from his house to the crossroads nn and Alex needs to get from his house to the crossroads 11 . And they don't want to meet at any of the crossroads, but they can meet in the middle of the street, when passing it in opposite directions. Alex and Bob asked you, as their mutual friend, to help them with this difficult task.

Find for Alex and Bob such routes with equal number of streets that the guys can follow these routes and never appear at the same crossroads at the same time. They are allowed to meet in the middle of the street when moving toward each other (see Sample 1). Among all possible routes, select such that the number of streets in it is the least possible. Until both guys reach their destinations, none of them can stay without moving.

The guys are moving simultaneously with equal speeds, i.e. it is possible that when one of them reaches some of the crossroads, the other one leaves it. For example, Alex can move from crossroad 11 to crossroad 22 , while Bob moves from crossroad 22 to crossroad 33 .

If the required routes don't exist, your program should output -1.

输入格式

The first line contains two integers nn and mm ( 2<=n<=500,1<=m<=100002<=n<=500,1<=m<=10000 ) — the amount of crossroads and the amount of roads. Each of the following mm lines contains two integers — the numbers of crossroads connected by the road. It is guaranteed that no road connects a crossroads with itself and no two crossroads are connected by more than one road.

输出格式

If the required routes don't exist, output -1. Otherwise, the first line should contain integer kk — the length of shortest routes (the length of the route is the amount of roads in it). The next line should contain k+1k+1 integers — Bob's route, i.e. the numbers of k+1k+1 crossroads passed by Bob. The last line should contain Alex's route in the same format. If there are several optimal solutions, output any of them.

输入输出样例

  • 输入#1

    2 1
    1 2
    

    输出#1

    1
    1 2 
    2 1 
    
  • 输入#2

    7 5
    1 2
    2 7
    7 6
    2 3
    3 4
    

    输出#2

    -1
    
  • 输入#3

    7 6
    1 2
    2 7
    7 6
    2 3
    3 4
    1 5
    

    输出#3

    6
    1 2 3 4 3 2 7 
    7 6 7 2 1 5 1 
    
首页