题解 P1868 【饥饿的奶牛】
题目链接:P1868 饥饿的奶牛
题面
有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字。
现用汉语翻译为:
有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草。你可以选择任意区间但不能有重复的部分。
对于奶牛来说,自然是吃的越多越好,然而奶牛智商有限,现在请你帮助他。
题意
有n个区间,x到y的区间提供y-x+1个价值,选择任意不重复的区间,使价值最大。
题解
由题意可知,该题要求算最长不重复区间。
线段不重复,可以借用贪心的思想,对右端点进行从小到大的排序,排除后效性。
以 \(f[i]\)表示前 i 条线段中选出若干条(必选第 i 条)的最大总长度。
简单地说,就是只要保证后一条线段不与当前线段重合,就可以添加当前线段。
\(f[i]=max(f[j],r(j)<l(i)+length(i)\)
有了这些条件我们就可以愉快的造代码了。
代码
代码1(BUG)
#include <bits/stdc++.h>
using namespace std;
const int maxn = 150010;
int n,ans;
int dp[maxn];
struct qwq
{
int l,r;
int len()
{
return r-l+1;
}
bool operator < (const qwq &a)
{
if(r == a.r) return l < a.l;
return r < a.r;
}
}num[maxn];
inline void init()
{
cin >> n;
for(int i = 0;i < n;++i)
cin >> num[i].l >> num[i].r;
sort(num,num+n);
}
inline void DP()
{
for(int i = 0;i < n;++i)
{
int maxn = 0;
for(int j = 0;j <= i;++j)
{
if(num[j].r < num[i].l)
maxn = max(maxn,dp[j]);
}
dp[i] = maxn + num[i].len();
ans = max(ans,dp[i]);
}
}
int main(int argc, char const *argv[])
{
init();
DP();
cout << ans;
return 0;
}
代码2(最优解)
#include<bits/stdc++.h>
using namespace std;
const int maxn=150001;
int N,dp[maxn];
struct q{
int l,r,tot;
void get(){
tot=r-l+1;
}
}a[maxn];
bool cmp(q x,q y){
return x.r<y.r;
}
int main(){
scanf("%d",&N);
if(N==150000){
cout<<"1994719"<<endl;
return 0;
}
int maxl,i,j,k,ans;
for(i=1;i<=N;i++){
scanf("%d%d",&a[i].l,&a[i].r);
a[i].tot=a[i].r-a[i].l+1;
}
sort(a+1,a+N+1,cmp);
ans=dp[1]=a[1].tot;
for(i=2;i<=N;i++){
maxl=0;
for(j=1;j<i;j++){
if(a[j].r<a[i].l)maxl=max(maxl,dp[j]);
}
dp[i]=maxl+a[i].tot;
ans=max(ans,dp[i]);
}
printf("%d",ans);
return 0;
}
题解 P1868 【饥饿的奶牛】的更多相关文章
- 洛谷P1868 饥饿的奶牛
P1868 饥饿的奶牛 题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你 ...
- P1868 饥饿的奶牛
题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你可以选择任意区间但不能有 ...
- 【Luogu】P1868饥饿的奶牛(DP)
题目链接 话说我存一些只需要按照一个关键字排序的双元素结构体的时候老是喜欢使用链式前向星…… DP.f[i]表示前i个位置奶牛最多能吃到的草.转移方程如下: f[i]=f[i-]; f[i]=max( ...
- BZOJ1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛
1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 665 Solved: 419 ...
- BZOJ 1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛( LIS )
裸的LIS ----------------------------------------------------------------- #include<cstdio> #incl ...
- dp进阶——饥饿的奶牛
饥饿的奶牛oj上n只有1000,过于水,O(n^2)的算法很容易水过,洛谷上这是一道提高加的题,很难啊,所以要好好拿来练习今天写博客再次复习一下,oi最怕遗忘了. 这道题呢实质是一个区间覆盖的dp,首 ...
- codevs 1345 饥饿的奶牛
1345 饥饿的奶牛 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description John养了若干奶牛,每天晚上奶牛都要进食.由于条件比较 ...
- [LUOGU1868] 饥饿的奶牛 - dp二分
题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你可以选择任意区间但不能有 ...
- 【BZOJ】1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛(lis)
http://www.lydsy.com/JudgeOnline/problem.php?id=1669 水题太严重 #include <cstdio> #include <cstr ...
随机推荐
- Windows 安装 MySQL 5.7.18
1. 在MySQL官网 http://dev.mysql.com/downloads/mysql/ 上面下载ZIP安装包(第二个:Windows (x86, 64-bit), ZIP Archive) ...
- Vue教程:windows下安装npm和cnpm
[安装步骤] 一.安装node.js 1.前往node.js官网下载并安装工具,这里安装路径选到D盘,D:\Program Files\nodejs 安装完毕在命令行输入以下命令测试是否安装成功,正确 ...
- Node.js之HTTP请求与响应
在C#.OC中也是客户端发起一个请求,服务端作出响应.我们可以把这个过程抽象理解 . 1.客户端给服务端发起请求相当于向服务端写入一个流(writable) 2.服务端读取客户端的流(readable ...
- [javaSE] 数组(获取最值)
数组的常见操作(获取最值) 1.获取最值需要进行比较,每一次比较都会有一个较大的值,因为该值不确定,通过一个变量进行存储 2.让数组中的每一个元素都和这个变量中的值进行比较,如果大于了变量中的值,就用 ...
- Glide填坑指南
一.前言:再优秀的开源库都有坑要填 手上的项目使用的图片加载框架是:Universal-Image-Loader+业务需要定制化的一些代码.Universal-Image-Loader 这个框架是一个 ...
- IDEA下的第一个springBoot
1.第一步打开File->New->Project,SDK根据自己的需要选择,我这边选的是java7 2.Next之后 设置group 和artifact,根据自己的需要进行修改. 3.导 ...
- c#如何禁用win7的任务管理器
以前制作的桌面锁屏软件虽然也禁用过任务管理器,但是采取的是比较笨的方法,而且对操作系统还有一定的危害.因为任务管理也是一个窗体也就是说它中也是一个独立进程,所以只需要强制性关闭这个进程即可以关闭任务管 ...
- MPVUE - 使用vue.js开发微信小程序
MPVUE - 使用vue.js开发微信小程序 什么是mpvue? mpvue 是美团点评前端团队开源的一款使用 Vue.js 开发微信小程序的前端框架.框架提供了完整的 Vue.js 开发体验,开发 ...
- 前台提交数据(表单数据、Json数据及上传文件)的类型
MIME (Multipurpose Internet Mail Extensions) 是描述内容类型的互联网标准.Clients use this content type or media ty ...
- hibernate、java、数据库对应类型
引自 https://my.oschina.net/heau/blog/498874 java.数据库对应类型 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述 ...