This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
# include <bits/stdc++.h>
# define pb push_back
# define fr first
# define sc second
# define mk make_pair
using namespace std;
const int inf = 1e9 + 7;
const int N = 1e6 + 5;
typedef long long ll;
int n, a[N];
ll ans, b[N], c[N], cb[N], cc[N], s1, s2;
int main()
{
cin >> n;
for(int i = 1; i <= n; i ++)
{
cin >> a[i] >> b[i] >> c[i];
cb[i] = b[i];
cc[i] = c[i];
b[i] += b[i - 1];
c[i] += c[i - 1];
}
for(int i = 1; i <= n; i ++)
{
// cout << "\\\\\\\\\\\\\\\\\\\n";
for(int j = i; j <= n; j ++)
{
ll res = b[j] - s1, sum = c[j] - s2;
// cout << sum + a[i] << " " << a[j] << " " << i << " " << j << endl;
// cout << sum + a[i] - a[j] << endl;
if(sum + a[i] < a[j]) continue;
ans = max(ans, res);
}
s1 += cb[i];
s2 += cc[i];
// for(int j = i; j <= n; j ++)
// b[j] -= cb[i], c[j] -= cc[i];
}
cout << ans << endl;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |