【USACO】约翰的聪明牛

题目描述

牛在饲料槽前排好了队。饲料槽依次用 1 到 N(1<=N<=2000)编号。每天晚上,一头幸运 的牛根据约翰的规则,吃其中一些槽里的饲料。 约翰提供 B 个区间的清单。一个区间是一对整数 start-end,1<=start<=end<=N,表示 一些连续的饲料槽,比如 1-3,7-8,3-4 等等。牛可以任意选择区间,但是牛选择的区间不能 有重叠。 当然,牛希望自己能够吃得越多越好。给出一些区间,帮助这只牛找一些区间,使它能 吃到最多的东西。 在上面的例子中,1-3 和 3-4 是重叠的;聪明的牛选择{1-3,7-8},这样可以吃到 5 个 槽里的东西。

输入

第一行,整数 B(1<=B<=1000) 第 2 到 B+1 行,每行两个整数,表示一个区间,较小的端点在前面。

输出

仅一个整数,表示最多能吃到多少个槽里的食物。

样例输入 
3    
1 3    
7 8    
3 4     
样例输出  
5

AC代码:

#include <bits/stdc++.h>
using namespace std;
const int maxm = 2005;
int dp[maxm];
struct node {
	int x;
	int y;
	int total;
};
bool cmp(node a, node b) {
	return  a.y < b.y;
}
int main() {
	int n;
	cin >> n;
	node s[n];
	for (int i = 0 ; i < n ; i++) {
		cin >> s[i].x >> s[i].y;
		s[i].total = s[i].y - s[i].x + 1; 
	}
	sort(s, s + n, cmp);
	for (int i = 0 ; i < n ; i++) {
		for (int j = s[n - 1].y ; j >= s[i].y ; j--)
			dp[j] = max(dp[j], dp[s[i].x - 1] + s[i].total);
	}
	cout << dp[s[n - 1].y];
	return 0;
}

 

  • 13
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值