#P1691. [ICPC 2016 WF] Oil

[ICPC 2016 WF] Oil

题目描述

A large part of the world economy depends on oil, which is why research into new methods for finding and extracting oil is still active. Profits of oil companies depend in part on how efficiently they can drill for oil. The International Crude Petroleum Consortium (ICPC) hopes that extensive computer simulations will make it easier to determine how to drill oil wells in the best possible way.

Drilling oil wells optimally is getting harder each day – the newly discovered oil deposits often do not form a single body, but are split into many parts. The ICPC is currently concerned with stratified deposits, as illustrated in Figure G.1.

To simplify its analysis, the ICPC considers only the 2-dimensional case, where oil deposits are modeled as horizontal line segments parallel to the earth’s surface. The ICPC wants to know how to place a single oil well to extract the maximum amount of oil. The oil well is drilled from the surface along a straight line and can extract oil from all deposits that it intersects on its way down, even if the intersection is at an endpoint of a deposit. One such well is shown as a dashed line in Figure G.1, hitting three deposits. In this simple model the amount of oil contained in a deposit is equal to the width of the deposit. Can you help the ICPC determine the maximum amount of oil that can be extracted by a single well?

输入格式

The first line of input contains a single integer n (1n20001 ≤ n ≤ 2 000), which is the number of oil deposits.

This is followed by nn lines, each describing a single deposit. These lines contain three integers x0x_0, x1x_1, and y giving the deposit’s position as the line segment with endpoints (x0,y)(x_0, y) and (x1,y)(x_1, y). These numbers satisfy x0,x1106|x_0|, |x_1| ≤ 10^6 and 1y1061 ≤ y ≤ 10^6 . No two deposits will intersect, not even at a point.

输出格式

Display the maximum amount of oil that can be extracted by a single oil well.

5
100 180 20
30 60 30
70 110 40
10 40 50
0 80 70
200
3
50 60 10
-42 -42 20
25 0 10
25