版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/wwwlps/article/details/81409071
题意:给奶牛挤奶,共m次可以挤,给出每次开始挤奶的时间st,结束挤奶的时间ed,还有挤奶的量ef,
每次挤完奶要休息r时间,问最大挤奶量.
题解:此题灵感来自于最长上升子序列的做法
#include <iostream>
#include <cstring>
#include <cstdio>
#include <vector>
#include <set>
#include <map>
#include <queue>
#include <algorithm>
#include <cmath>
#define maxn 1005
#define maxz 2005
#define INF 0x3f3f3f3f
#define LL long long
using namespace std;
int zh,m,rest;
struct node
{
int l,r,eff;
int len;
}cow[maxn];
int dp[maxn];
bool cmp(node a,node b)
{
return a.l<b.l;
}
void solve()
{
memset(dp,0,sizeof(dp));
int ans=0;
for(int i=0;i<m;i++)
{
dp[i]=cow[i].eff;
for(int j=0;j<i;j++)
{
if(cow[i].l-cow[j].r>=rest)
{
dp[i]=max(dp[i],dp[j]+cow[i].eff);
}
}
ans=max(ans,dp[i]);
}
cout << ans << endl;
}
int main()
{
cin>>zh>>m>>rest;
for(int i=0;i<m;i++)
{
int l,r,eff;
cin>>l>>r>>eff;
cow[i].l=l;
cow[i].r=r;
cow[i].eff=eff;
cow[i].len=r-l;
}
sort(cow,cow+m,cmp);
solve();
return 0;
}