1. 程式人生 > >CodeForces 867C Ordering Pizza 貪心,思維

CodeForces 867C Ordering Pizza 貪心,思維

make ces origin 類型 push_back pac stack bits ref

CodeForces 867C

題意:一個pizza 可以分成 s 塊,有兩種類型的 pizza 。有 n 個人,每個人要吃 si 塊 pizza,且吃一塊類型 1 的 pizza可以得到 ai 的價值,吃一塊類型 2 的 pizza得到 bi 的價值。問:在訂購 pizza 個數最少的情況下,求 n 個人能得到的最大價值。

tags:一開始想到每個人取最大價值的類型,但沒繼續想了。。

其實就是先假定每個取最大價值類型,然後看兩種類型余下的個數是否可以用一個 pizza代替,再整一下就是了。

#include<bits/stdc++.h>
using namespace
std; #pragma comment(linker, "/STACK:102400000,102400000") #define rep(i,a,b) for (int i=a; i<=b; ++i) #define per(i,b,a) for (int i=b; i>=a; --i) #define mes(a,b) memset(a,b,sizeof(a)) #define INF 0x3f3f3f3f #define MP make_pair #define PB push_back #define fi first #define se second typedef
long long ll; const int N = 200005; struct P { ll a, b, ab, s; bool friend operator < (P x, P y) { return x.ab<y.ab; } }p[N]; ll n, cnt1, cnt2, s, ans; int main() { scanf("%lld%lld", &n, &s); rep(i,1,n) { scanf("%lld%lld%lld", &p[i].s, &p[i].a, &p[i].b); p[i].ab
= p[i].a-p[i].b; } sort(p+1, p+1+n); rep(i,1,n) { if(p[i].a>p[i].b) { ans += p[i].a*p[i].s; cnt1 += p[i].s; } else { ans += p[i].b*p[i].s; cnt2 += p[i].s; } } cnt1%=s, cnt2%=s; if(cnt1+cnt2 <= s) { ll ans1=ans, ans2=ans, num; for(int i=n; cnt2 && i>=1; --i) if(p[i].ab<=0) { num = min(cnt2, p[i].s); ans1 += num*p[i].ab; cnt2 -= num; } for(int i=1; cnt1 && i<=n; ++i) if(p[i].ab>0) { num = min(cnt1, p[i].s); ans2 += num*(-p[i].ab); cnt1 -= num; } ans = max(ans1, ans2); } printf("%lld\n", ans); return 0; }

CodeForces 867C Ordering Pizza 貪心,思維