C. Road to Cinema

Codeforces
IDCF738C
Time1000ms
Memory256MB
Difficulty
binary search
Vasya is currently at a car rental service, and he wants to reach cinema. The film he has bought a ticket for starts in _t_ minutes. There is a straight road of length _s_ from the service to the cinema. Let's introduce a coordinate system so that the car rental service is at the point 0, and the cinema is at the point _s_. There are _k_ gas stations along the road, and at each of them you can fill a car with any amount of fuel for free! Consider that this operation doesn't take any time, i.e. is carried out instantly. There are _n_ cars in the rental service, _i_\-th of them is characterized with two integers _c__i_ and _v__i_ — the price of this car rent and the capacity of its fuel tank in liters. It's not allowed to fuel a car with more fuel than its tank capacity _v__i_. All cars are completely fueled at the car rental service. Each of the cars can be driven in one of two speed modes: normal or accelerated. In the normal mode a car covers 1 kilometer in 2 minutes, and consumes 1 liter of fuel. In the accelerated mode a car covers 1 kilometer in 1 minutes, but consumes 2 liters of fuel. The driving mode can be changed at any moment and any number of times. Your task is to choose a car with minimum price such that Vasya can reach the cinema before the show starts, i.e. not later than in _t_ minutes. Assume that all cars are completely fueled initially. ## Input The first line contains four positive integers _n_, _k_, _s_ and _t_ (1 ≤ _n_ ≤ 2·105, 1 ≤ _k_ ≤ 2·105, 2 ≤ _s_ ≤ 109, 1 ≤ _t_ ≤ 2·109) — the number of cars at the car rental service, the number of gas stations along the road, the length of the road and the time in which the film starts. Each of the next _n_ lines contains two positive integers _c__i_ and _v__i_ (1 ≤ _c__i_, _v__i_ ≤ 109) — the price of the _i_\-th car and its fuel tank capacity. The next line contains _k_ **distinct** integers _g_1, _g_2, ..., _g__k_ (1 ≤ _g__i_ ≤ _s_ - 1) — the positions of the gas stations on the road in arbitrary order. ## Output Print the minimum rent price of an appropriate car, i.e. such car that Vasya will be able to reach the cinema before the film starts (not later than in _t_ minutes). If there is no appropriate car, print _\-1_. [samples] ## Note In the first sample, Vasya can reach the cinema in time using the first or the third cars, but it would be cheaper to choose the first one. Its price is equal to 10, and the capacity of its fuel tank is 8. Then Vasya can drive to the first gas station in the accelerated mode in 3 minutes, spending 6 liters of fuel. After that he can full the tank and cover 2 kilometers in the normal mode in 4 minutes, spending 2 liters of fuel. Finally, he drives in the accelerated mode covering the remaining 3 kilometers in 3 minutes and spending 6 liters of fuel.
Samples
Input #1
3 1 8 10
10 8
5 7
11 9
3
Output #1
10
Input #2
2 2 10 18
10 4
20 6
5 3
Output #2
20
API Response (JSON)
{
  "problem": {
    "name": "C. Road to Cinema",
    "description": {
      "content": "Vasya is currently at a car rental service, and he wants to reach cinema. The film he has bought a ticket for starts in _t_ minutes. There is a straight road of length _s_ from the service to the cine",
      "description_type": "Markdown"
    },
    "platform": "Codeforces",
    "limit": {
      "time_limit": 1000,
      "memory_limit": 262144
    },
    "difficulty": "None",
    "is_remote": true,
    "is_sync": true,
    "sync_url": null,
    "sign": "CF738C"
  },
  "statements": [
    {
      "statement_type": "Markdown",
      "content": "Vasya is currently at a car rental service, and he wants to reach cinema. The film he has bought a ticket for starts in _t_ minutes. There is a straight road of length _s_ from the service to the cine...",
      "is_translate": false,
      "language": "English"
    }
  ]
}
Full JSON Raw Segments