题解:P12247 跳舞机
- 注:本题虽然正解形式简单,代码简短,但对于普及组选手,需要一定的思维能力和经验积累才能做出此题,且对于思考的过程,带有许多合适的部分分。
考察贪心、简单动态规划、stl 库的数据结构应用。
考虑设
考虑求出所有
问题转换为,有
我们考虑维护一个可重集 std::map 或者 std::multiset 维护即可。
如果没想到正解,可以得到贪心的部分分或者不包含数据结构的部分分。
#include<bits/stdc++.h>
#define ll long long
#define rep(x,y,z) for(int x=(y);x<=(z);x++)
#define per(x,y,z) for(int x=(y);x>=(z);x--)
#define repn(x) rep(x,1,n)
#define repm(x) rep(x,1,m)
#define pb push_back
inline int read(){int s=0,w=1;char c=getchar();while(c<48||c>57) {if(c=='-') w=-1;c=getchar();}while(c>=48&&c<=57)s=(s<<1)+(s<<3)+c-48,c=getchar();return s*w;}
inline void pf(ll x){if(x<0) putchar('-'),x=-x;if(x>9)pf(x/10);putchar(x%10+48);}
using namespace std;
const int N=5e5+5;
int n,m,k;
ll dp[N];
struct node{
int k,ty;
};
vector<node>p[N];
map<int,int>P;
inline void Main(){
n=read(),m=read(),k=read();
repn(i){
int l=read()+k-1,r=read(),w=read();
if(l<=r)p[l].pb({w,1}),p[r+1].pb({w,-1});
}
repm(i){
for(auto y:p[i])if(y.ty==1)P[y.k]++;
else {
if(P[y.k]==1)P.erase(y.k);
else P[y.k]--;
}
dp[i]=dp[i-1];
if(!P.empty())dp[i]=max(dp[i],dp[i-k]+(*--P.end()).first);
}
cout <<dp[m];
}
signed main(){
int T=1;
while(T--)Main();
return 0;
}