{"raw_statement":[{"iden":"statement","content":"An electrician Vasya has got an assignment to solder n wires. His boss specified the requirements precisely, so for each wire Vasya knows exactly where its endpoints should be soldered to. Two identifiers ai, bi are given for each wire, meaning that one endpoint of the wire should be soldered to the place ai, and the other endpoint should be soldered to the place bi. It doesn't matter which endpoint will be soldered to which place. Also each wire has two more characteristics ri and pi, where ri is its reliability and pi is its cost. \n\nThe only way for Vasya to express himself in such a rigorous constraints is to choose an order, and solder all wires in this order, one after another. As an experienced electrician Vasya knows what a short circuit is — it occurs when a scheme contains a cycle, in other words when there is more than one simple path over wires from one place to another. So, if a short circuit occurs after a wire is soldered, the least reliable wire in the cycle burns out (you may think that the least reliable wire disappears from the scheme). If there are several least reliable wires in the cycle, the one of them which was soldered earlier burns out. It is clear that after a wire burns out, the scheme doesn't have any cycles.\n\nWhen Vasya is done with soldering, he ends up with a scheme of soldered wires. So, he wants to solder all wires in such an order, that the total cost of wires in a resulting scheme will be as maximal as possible.\n\nThe first line of input contains a single integer n (1 ≤ n ≤ 30000). Each of the following n lines contains four integer numbers ai, bi, ri, pi (1 ≤ ai, bi, ri, pi ≤ 109;ai ≠ bi), where ai and bi are identifiers of the places for endpoints of i-th wire, ri is the reliability of the wire, and pi is the cost of the wire. There can be more than one wire between any pair of places.\n\nPrint the required maximal total cost to the first line of output. Print the order of wires for soldering to the second line, delimiting wire indices with a single space.\n\nYou may print any solution if there are many of them. \n\nIn the sample test Vasya can choose any order with the only rule: the second wire should be soldered before the first one. If he violates the rule, the total cost will be 4 instead of 5.\n\n"},{"iden":"input","content":"The first line of input contains a single integer n (1 ≤ n ≤ 30000). Each of the following n lines contains four integer numbers ai, bi, ri, pi (1 ≤ ai, bi, ri, pi ≤ 109;ai ≠ bi), where ai and bi are identifiers of the places for endpoints of i-th wire, ri is the reliability of the wire, and pi is the cost of the wire. There can be more than one wire between any pair of places."},{"iden":"output","content":"Print the required maximal total cost to the first line of output. Print the order of wires for soldering to the second line, delimiting wire indices with a single space.You may print any solution if there are many of them. "},{"iden":"examples","content":"Input410 20 5 320 11 5 210 11 7 11 2 1 1Output52 3 1 4 "},{"iden":"note","content":"In the sample test Vasya can choose any order with the only rule: the second wire should be soldered before the first one. If he violates the rule, the total cost will be 4 instead of 5."}],"translated_statement":null,"sample_group":[],"show_order":[],"formal_statement":"**Definitions**  \nLet $ R, C \\in \\mathbb{Z} $ denote the number of rows and columns of the grid, with $ 1 \\leq R, C \\leq 100 $.  \nLet $ G = (g_{i,j})_{1 \\leq i \\leq R, 1 \\leq j \\leq C} $ be the grid, where each $ g_{i,j} \\in \\{>, -, |\\} $.  \n\nThe player starts at $ (1,1) $ and may only move right or down, ending at any cell $ (i,j) $ with $ i \\leq R $, $ j \\leq C $.  \nThe player collects the symbol in each visited cell.  \nThe player has an infinite supply of symbols $ \\{x, o\\} $.  \n\nA Hackatari logo is a multiset of five symbols: $ \\{x, o, >, -, |\\} $.  \n\n**Constraints**  \n1. The player’s path is a monotonic path from $ (1,1) $ to some $ (i,j) $, moving only right or down.  \n2. The path length is $ i + j - 1 $.  \n3. The collected symbols are exactly those in the cells along the path.  \n\n**Objective**  \nMaximize the number of complete Hackatari logos that can be formed from:  \n- The infinite supply of $ x $ and $ o $,  \n- The collected multiset of symbols $ \\{>, -, |\\} $ from the path.  \n\nLet $ n_{>} $, $ n_{-} $, $ n_{|} $ be the counts of $ > $, $ - $, $ | $ collected along a path.  \nEach logo requires exactly one of each: $ > $, $ - $, $ | $.  \nThus, the number of logos formable along a path is:  \n$$\n\\min(n_{>}, n_{-}, n_{|})\n$$\n\nFind:  \n$$\n\\max_{\\text{all valid paths from } (1,1)} \\left( \\min(n_{>}, n_{-}, n_{|}) \\right)\n$$","simple_statement":"You are given an R×C grid with symbols '>', '-', or '|' in each cell.  \nYou start at the top-left corner and can only move right or down.  \nYou collect symbols as you move.  \nYou also have unlimited 'x' and 'o'.  \nA Hackatari logo needs exactly: one 'x', one 'o', one '>', one '-', and one '|'.  \nFind the maximum number of complete logos you can build by collecting symbols along one path.","has_page_source":false}