제출 #1060100

#제출 시각아이디문제언어결과실행 시간메모리
1060100PiokemonCloud Computing (CEOI18_clo)C++17
18 / 100
133 ms2388 KiB
#include <bits/stdc++.h> using namespace std; typedef long long int ll; constexpr int N = 2000; ll kompy[N+9][3]; // ile f koszt ll osoby[N+9][3]; ll cheapk[N*50+9]; ll buyer[N*50+9]; int main(){ ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0); int n,m; cin >> n; bool c1=1,f1=1; for (int x=1;x<=n;x++){ cin >> kompy[x][0] >> kompy[x][1] >> kompy[x][2]; if (kompy[x][0]>1)c1=0; if (kompy[x][1]>1)f1=0; } cin >> m; for (int x=1;x<=m;x++){ cin >> osoby[x][0] >> osoby[x][1] >> osoby[x][2]; if (osoby[x][0]>1)c1=0; if (osoby[x][1]>1)f1=0; } if (c1){ vector<pair<ll,ll>> kup; priority_queue<ll> mozl; vector<pair<ll,ll>> oso; for (int x=1;x<=n;x++)kup.push_back({kompy[x][1],kompy[x][2]}); kup.push_back({-1,1e9}); sort(kup.begin(),kup.end(),greater<pair<ll,ll>>()); for (int x=1;x<=m;x++)oso.push_back({osoby[x][1],osoby[x][2]}); sort(oso.begin(),oso.end()); mozl.push(-2e9); int p=0; ll odp=0; for (int x=m-1;x>=0;x--){ while(kup[p].first>=oso[x].first){ mozl.push(-kup[p].second); p++; } if (-mozl.top()<oso[x].second){ odp += oso[x].second+mozl.top(); mozl.pop(); mozl.push(-oso[x].second); } } cout << odp << '\n'; return 0; } if (f1){ for (int x=0;x<=max(n,m)*50;x++){ cheapk[x]=(ll)1e18; buyer[x]=(ll)-1e18; } buyer[0]=0; cheapk[0]=0; for (int x=1;x<=n;x++){ for (int y=50*(x+1);y>=kompy[x][0];y--){ cheapk[y]=min(cheapk[y],cheapk[y-kompy[x][0]]+kompy[x][2]); } } for (int x=1;x<=m;x++){ for (int y=50*(x+1);y>=osoby[x][0];y--){ buyer[y]=max(buyer[y],buyer[y-osoby[x][0]]+osoby[x][2]); } } ll odp=0; for (int x=50*n;x>=1;x--)cheapk[x-1]=min(cheapk[x-1],cheapk[x]); for (int x=0;x<=50*min(n,m);x++){ buyer[x]=max(buyer[x],buyer[x-1]); odp=max(odp,buyer[x]-cheapk[x]); } cout << odp << '\n'; return 0; } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...