poj 3616 Milking Time(dp,类似于最长上升子序列)

版权声明:本文为博主原创文章,未经博主允许不得转载。 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;
}

猜你喜欢

转载自blog.csdn.net/wwwlps/article/details/81409071