Polish version    English version  
  About Olympic -> Problems -> XI OI 2003/2004


 News
 About Olympic
About contest
Problems
I OI 1993/1994
II OI 1994/1995
III OI 1995/1996
IV OI 1996/1997
V OI 1997/1998
VI OI 1998/1999
VII OI 1999/2000
VIII OI 2000/2001
IX OI 2001/2002
X OI 2002/2003
XI OI 2003/2004
XII OI 2004/2005
XIII OI 2005/2006
XIV OI 2006/2007
XV OI 2007/2008
Problems archive
 History of OI
 OI books
 National team
 Olympic camps
 Photo gallery
 Links
 SIO
 MAIN
XI Olimpiad in Informatics 2003/2004

Task: zaw

The competition

I stage competition  
Source file: zaw.xxx (xxx=pas,c,cpp)
Memory limit: 16 MB

At the foot of Mt.Byte there is an entrance to a cave. The cave consists of a complex system of chambers connected with tunnels. The cave entrance leads straight to a chamber called the front chamber. The tunnels do not intersect (they meet only in chambers). Two chambers can either be connected with a single tunnel, or not be connected at all (it may, however, be possible to reach one chamber from the other via remaining chambers). A tunnel always connects two distinct chambers.

It has been decided that 'King's of Byteotia Cup' competition is to be organized. The goal of each competitor is to traverse a freely chosen route in the cave and get out as quickly as possible. The route has to lead through at least one other chamber than the front one. Only two rules are in force: during the travel through the cave each chamber (with the exception of the front chamber) can be visited once at the most, similarly each corridor cannot be crossed more than once.

A fameous cave explorer Byteala is preparing himslef for the competition. Byteala has been training in the cave for a long time and he has acquired a detailed knowledge of the corridor system. For each corridor he has calculated the amount of time needed to cross it in each direction. The time necessary to move within the chambers can be neglected. Now Byteala would like to calculate a route satisfying requirements of the competition, which can be traversed in the least time possible (the time necessary to traverse a route is the sum of the times needed to cross corridors which it consists of).

Task

Help Byteala! Write a programme which:

  • reads from the standard input a description of the cave and times necessary to cross each corridor,
  • calculates a route consistent with the requirements, for which the sum of times needed to cross the corridors it comprises is minimal,
  • writes to the standard output the time required to traverse the calculated route.

Input

In the first line of the input there are two integers n and m (3 <= n <= 5000, 3 <= m <= 10000) separated by a single space denoting the number of chambers in the cave and the number of interlinking corridors, respectively. The chambers are numbered from 1 to n. The front chamber is denoted by 1. The following m lines contain a description of the corridors. In each of these lines there are four integers separated by single spaces. A 4-tuple a,b,c,d means that chambers a and b are connected with a corridor, the crossing time from a to b is c and from b to a is d, 1 <= a,b <= n, a <> b, 1 <= c,d <= 10000. You can assume that a route satisfying requirements of the competition always exists.

Output

Your programme should write in the first (and only) line of the output one integer - the minimal time required to traverse a route satisfying conditions of the competition.

Example

For the input data:

3 3
1 2 4 3
2 3 4 2
1 3 1 1

the correct outcome is:

6



Print friendly version