There are n n ncities along the road, which can be represented as a straight line. The i i i-th city is situated at the distance of a i a_i ai kilometers from the origin. All cities are situated in the same direction from the origin. There are ? trucks travelling from one city to another.
Each truck can be described by 4 integers: starting city s i s_i si, finishing city f i f_i fi, fuel consumption c i c_i ci and number of possible refuelings r i r_i ri. The i i i-th truck will spend c i c_i ci litres of fuel per one kilometer.
When a truck arrives in some city, it can be refueled (but refueling is impossible in the middle of nowhere). The i i i-th truck can be refueled at most r i r_i ri times. Each refueling makes truck’s gas-tank full. All trucks start with full gas-tank.
All trucks will have gas-tanks of the same size V V V litres. You should find minimum possible V V V such that all trucks can reach their destinations without refueling more times than allowed.
First line contains two integers n n n and m m m ( 2 ≤ n ≤ 400 , 1 ≤ m ≤ 250000 ) (2≤n≤400, 1≤m≤250000) (2≤n≤400,1≤m≤250000) — the number of cities and trucks.
The second line contains n n n integers a 1 , a 2 , … , a n ( 1 ≤ a i ≤ 1 0 9 , a i < a i + 1 ) a_1,a_2,…,a_n (1≤a_i≤10^9, a_i<a_i+1) a1,a2,…,an(1≤ai≤109,ai<ai+1) — positions of cities in the ascending order.
Next m m m lines contains 4 4 4 integers each. The i i i-th line contains integers s i , f i , c i , r i ( 1 ≤ s i < f i ≤ n , 1 ≤ c i ≤ 1 0 9 , 0 ≤ r i ≤ n ) s_i, f_i, c_i, r_i (1≤s_i<f_i≤n, 1≤c_i≤10^9, 0≤r_i≤n) si,fi,ci,ri(1≤si<fi≤n,1≤ci≤109,0≤ri≤n) — the description of the i i i-th truck.
Print the only integer — minimum possible size of gas-tanks V V V such that all trucks can reach their destinations.
7 6
2 5 7 10 14 15 17
1 3 10 0
1 7 12 7
4 5 13 3
4 7 10 1
4 7 10 1
1 5 11 2
55
Let’s look at queries in details:
the 1-st truck must arrive at position 7 from 2 without refuelling, so it needs gas-tank of volume at least 50.
the 2-nd truck must arrive at position 17 from 2 and can be refueled at any city (if it is on the path between starting point and ending point), so it needs gas-tank of volume at least 48.
the 3-rd truck must arrive at position 14 from 10, there is no city between, so it needs gas-tank of volume at least 52.
the 4-th truck must arrive at position 17 from 10 and can be refueled only one time: it’s optimal to refuel at 5-th city (position 14) so it needs gas-tank of volume at least 40.
the 5-th truck has the same description, so it also needs gas-tank of volume at least 40.
the 6-th truck must arrive at position 14 from 2 and can be refueled two times: first time in city 2 or 3 and second time in city 4 so it needs gas-tank of volume at least 55.
#include
using namespace std;
const int maxn=250010;
typedef long long ll;
int ans[maxn],n,m,a[405],b[maxn][4];
bool check(int cur,int k)
{
int last=b[cur][0],cnt=0;
int s=b[cur][0];
while(s<b[cur][1]){
while(s+1<=b[cur][1]&&a[s+1]-a[last]<=k){
s++;
}
if(last==s) return false;
last=s;
cnt++;
}
return cnt-1<=b[cur][3];
}
int main()
{
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
for(int i=1;i<=m;i++) {
scanf("%d %d %d %d",&b[i][0],&b[i][1],&b[i][2],&b[i][3]);
int l=1,r=a[b[i][1]]-a[b[i][0]]+1;
while(l<r){
int mid=(l+r)>>1;
if(check(i,mid)) r=mid;
else l=mid+1;
}
ans[i]=r;
}
ll res=0;
for(int i=1;i<=m;i++) res=max(res,(ll)b[i][2]*ans[i]);
printf("%lld\n",res);
}
#include
using namespace std;
typedef long long ll;
int n,m,b,c,d,e,dp[405][405][405],a[405];
int main()
{
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++) scanf("%d",&a[i]);
for(int i=1;i<=n;i++) for(int j=i+1;j<=n;j++) dp[i][j][0]=a[j]-a[i];
for(int k=1;k<=n;k++){
for(int i=1;i<=n;i++){
int point = i;
for(int j=i+1;j<=n;j++){
while(point<j&&max(dp[i][point][k-1],a[j]-a[point])>max(dp[i][point+1][k-1],a[j]-a[point+1])) ++point;
dp[i][j][k]=max(dp[i][point][k-1],a[j]-a[point]);
}
}
}
ll ans=0;
for(int i=1;i<=m;i++) {
scanf("%d %d %d %d",&b,&c,&d,&e);
ans=max(ans,1ll*dp[b][c][e]*d);
}
printf("%lld\n",ans);
}