Submission #108839

# Submission time Handle Problem Language Result Execution time Memory
108839 2019-05-02T09:38:41 Z antimirage Two Dishes (JOI19_dishes) C++14
0 / 100
442 ms 32504 KB
/**
	Elohim Essaim, Elohim Essaim I implore you...
**/
#include <bits/stdc++.h>
 
#define fr first
#define sc second
#define mk make_pair
#define pb push_back
#define all(s) s.begin(), s.end()
 
using namespace std;
 
const int N = 1e6 + 5;
 
int n, m, a[N], b[N], p[N], q[N];
 
long long ans, mx[N * 4], lz[N * 4], inf = 1e18, s[N], t[N], pr1[N], pr2[N];
 
map < pair<int, int>, long long> mp;
 
void push(int v, int tl, int tr){
	
	if (lz[v]){
		mx[v] += lz[v];
		
		if (tl != tr)
			lz[v + v] += lz[v],
			lz[v + v + 1] += lz[v];
			
		lz[v] = 0;
	}
}
 
void add (int l, int r, long long val, int v = 1, int tl = 0, int tr = n)
{
	push(v, tl, tr);
	
	if (l > tr || tl > r) return;
	
	if (l <= tl && tr <= r)
	{
		lz[v] = val;
		push(v, tl , tr);
		return;
	}
	int tm = (tl + tr) >> 1;
	
	add(l, r, val, v + v, tl, tm);
	add(l, r, val, v + v + 1, tm + 1, tr);
	
	mx[v] = max(mx[v + v], mx[v + v + 1]);
}
long long get (int l, int r, int v = 1, int tl = 0, int tr = n)
{
	push(v, tl, tr);
	if (l > tr || tl > r || l > r)
		return -inf;
		
	if (l <= tl && tr <= r)
		return mx[v];
	
	int tm = (tl + tr) >> 1;
	
	return max( get(l, r, v + v, tl, tm), get(l, r, v + v + 1, tm + 1, tr) );
}
void update (int pos, long long val, int v = 1, int tl = 0, int tr = n)
{
	push(v, tl, tr);
	
	if (tl == tr)
		mx[v] = max(mx[v], val);
	else{
		int tm = (tl + tr) >> 1;
		
		if (pos <= tm)
			update(pos, val, v + v, tl, tm);
		else
			update(pos, val, v + v + 1, tm + 1, tr);
			
		mx[v] = max( mx[v + v], mx[v + v + 1] );
	}
}
main(){
	cin >> n >> m;
	
	for (int i = 1; i <= n; i++){
		
		scanf("%d%lld%d", &a[i], &s[i], &p[i]);
		pr1[i] = pr1[i - 1] + a[i];
	}	
	for (int i = 1; i <= m; i++){
		
		scanf("%d%lld%d", &b[i], &t[i], &q[i]);
		pr2[i] = pr2[i - 1] + b[i];
	}
	for (int i = 1; i <= n; i++)
	{
		if (pr1[i] > s[i]) continue;
		
		
		if ( pr1[i] + pr2[m] <= s[i] ) {
			ans += p[i];
			continue;
		}
		
		int j = upper_bound( pr2 + 1, pr2 + 1 + m, s[i] - pr1[i] ) - pr2 - 1;
		
		mp[ mk(j, -i) ] += p[i];
	}	
	for (int i = 1; i <= m; i++)
	{
		if (pr2[i] > t[i]) continue;
		
		ans += q[i];
		
		if ( pr2[i] + pr1[n] <= t[i] ) {
			continue;	
		}
		
		int j = upper_bound( pr1 + 1, pr1 + 1 + n, t[i] - pr2[i] ) - pr1 - 1;
		
		mp[ mk(i - 1, -j - 1) ] -= q[i];
	}
	for (auto it : mp)
	{
		update( -it.fr.sc, get(0, (-it.fr.sc) - 1) );
		
		add( -it.fr.sc, n, it.sc);
	}
	cout << mx[1] + ans << endl;
}
/**
11
10
10 15 80
55 28 -91
12 6 52
43 64 18
59 95 -57
59 77 57
56 68 -77
73 82 -95
44 59 -88
62 49 18
29 10 -2
35 62 28
76 81 -2
5 71 -50
53 31 36
84 96 89
48 10 -22
15 82 -38
56 64 -51
4 70 -48
10 9 -63

**/

Compilation message

dishes.cpp:84:6: warning: ISO C++ forbids declaration of 'main' with no type [-Wreturn-type]
 main(){
      ^
dishes.cpp: In function 'int main()':
dishes.cpp:89:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%lld%d", &a[i], &s[i], &p[i]);
   ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
dishes.cpp:94:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   scanf("%d%lld%d", &b[i], &t[i], &q[i]);
   ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 442 ms 32504 KB Output is correct
2 Incorrect 420 ms 31580 KB Output isn't correct
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 3 ms 256 KB Output is correct
4 Correct 2 ms 384 KB Output is correct
5 Correct 2 ms 384 KB Output is correct
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Correct 2 ms 384 KB Output is correct
9 Correct 3 ms 384 KB Output is correct
10 Incorrect 2 ms 384 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 3 ms 256 KB Output is correct
4 Correct 2 ms 384 KB Output is correct
5 Correct 2 ms 384 KB Output is correct
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Correct 2 ms 384 KB Output is correct
9 Correct 3 ms 384 KB Output is correct
10 Incorrect 2 ms 384 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 3 ms 256 KB Output is correct
4 Correct 2 ms 384 KB Output is correct
5 Correct 2 ms 384 KB Output is correct
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Correct 2 ms 384 KB Output is correct
9 Correct 3 ms 384 KB Output is correct
10 Incorrect 2 ms 384 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 3 ms 256 KB Output is correct
4 Correct 2 ms 384 KB Output is correct
5 Correct 2 ms 384 KB Output is correct
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Correct 2 ms 384 KB Output is correct
9 Correct 3 ms 384 KB Output is correct
10 Incorrect 2 ms 384 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 2 ms 384 KB Output is correct
2 Correct 2 ms 384 KB Output is correct
3 Correct 3 ms 256 KB Output is correct
4 Correct 2 ms 384 KB Output is correct
5 Correct 2 ms 384 KB Output is correct
6 Correct 2 ms 384 KB Output is correct
7 Correct 2 ms 384 KB Output is correct
8 Correct 2 ms 384 KB Output is correct
9 Correct 3 ms 384 KB Output is correct
10 Incorrect 2 ms 384 KB Output isn't correct
11 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 442 ms 32504 KB Output is correct
2 Incorrect 420 ms 31580 KB Output isn't correct
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 442 ms 32504 KB Output is correct
2 Incorrect 420 ms 31580 KB Output isn't correct
3 Halted 0 ms 0 KB -