|Codeforces Round #189 (Div. 1)|
Kalila and Dimna are two jackals living in a huge jungle. One day they decided to join a logging factory in order to make money.
The manager of logging factory wants them to go to the jungle and cut n trees with heights a 1, a 2, ..., a n. They bought a chain saw from a shop. Each time they use the chain saw on the tree number i, they can decrease the height of this tree by one unit. Each time that Kalila and Dimna use the chain saw, they need to recharge it. Cost of charging depends on the id of the trees which have been cut completely (a tree is cut completely if its height equal to 0). If the maximum id of a tree which has been cut completely is i (the tree that have height a i in the beginning), then the cost of charging the chain saw would be b i. If no tree is cut completely, Kalila and Dimna cannot charge the chain saw. The chainsaw is charged in the beginning. We know that for each i < j, a i < a j and b i > b j and also b n = 0 and a 1 = 1. Kalila and Dimna want to cut all the trees completely, with minimum cost.
They want you to help them! Will you?
The first line of input contains an integer n (1 ≤ n ≤ 105). The second line of input contains n integers a 1, a 2, ..., a n (1 ≤ a i ≤ 109). The third line of input contains n integers b 1, b 2, ..., b n (0 ≤ b i ≤ 109).
It's guaranteed that a 1 = 1, b n = 0, a 1 < a 2 < ... < a n and b 1 > b 2 > ... > b n.
The only line of output must contain the minimum cost of cutting all the trees completely.
Please, do not write the %lld specifier to read or write 64-bit integers in С++. It is preferred to use the cin, cout streams or the %I64d specifier.
1 2 3 4 5
5 4 3 2 0
1 2 3 10 20 30
6 5 4 3 2 0