题目链接:P1868 饥饿的奶牛

题面

有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字。

现用汉语翻译为:

有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草。你可以选择任意区间但不能有重复的部分。

对于奶牛来说,自然是吃的越多越好,然而奶牛智商有限,现在请你帮助他。

题意

有n个区间,x到y的区间提供y-x+1个价值,选择任意不重复的区间,使价值最大。

题解

由题意可知,该题要求算最长不重复区间。

  1. 线段不重复,可以借用贪心的思想,对右端点进行从小到大的排序,排除后效性。

  2. 以 \(f[i]\)表示前 i 条线段中选出若干条(必选第 i 条)的最大总长度。

  3. 简单地说,就是只要保证后一条线段不与当前线段重合,就可以添加当前线段。

  4. \(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 【饥饿的奶牛】的更多相关文章

  1. 洛谷P1868 饥饿的奶牛

    P1868 饥饿的奶牛 题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你 ...

  2. P1868 饥饿的奶牛

    题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你可以选择任意区间但不能有 ...

  3. 【Luogu】P1868饥饿的奶牛(DP)

    题目链接 话说我存一些只需要按照一个关键字排序的双元素结构体的时候老是喜欢使用链式前向星…… DP.f[i]表示前i个位置奶牛最多能吃到的草.转移方程如下: f[i]=f[i-]; f[i]=max( ...

  4. BZOJ1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛

    1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 665  Solved: 419 ...

  5. BZOJ 1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛( LIS )

    裸的LIS ----------------------------------------------------------------- #include<cstdio> #incl ...

  6. dp进阶——饥饿的奶牛

    饥饿的奶牛oj上n只有1000,过于水,O(n^2)的算法很容易水过,洛谷上这是一道提高加的题,很难啊,所以要好好拿来练习今天写博客再次复习一下,oi最怕遗忘了. 这道题呢实质是一个区间覆盖的dp,首 ...

  7. codevs 1345 饥饿的奶牛

    1345 饥饿的奶牛  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题目描述 Description John养了若干奶牛,每天晚上奶牛都要进食.由于条件比较 ...

  8. [LUOGU1868] 饥饿的奶牛 - dp二分

    题目描述 有一条奶牛冲出了围栏,来到了一处圣地(对于奶牛来说),上面用牛语写着一段文字. 现用汉语翻译为: 有N个区间,每个区间x,y表示提供的x~y共y-x+1堆优质牧草.你可以选择任意区间但不能有 ...

  9. 【BZOJ】1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛(lis)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1669 水题太严重 #include <cstdio> #include <cstr ...

随机推荐

  1. 扫描网站服务器真实IP的小脚本

    #!/usr/bin/env python # -*- coding: gbk -*- # -*- coding: utf_8 -*- # Date: 2015年9月11日 # Author:蔚蓝行 ...

  2. .Net调用Java端带有WS-Security支持的Web Service【亲测通过】

    做了几年的开发,今天终于鼓起勇气开通了博客园.平时都是找各种大牛,看他们的分享博客的解决BUG.从今天起,我也开始分享我学习之路.还望大家多多支持! 最近收到一个采用Axis2实现的WebServic ...

  3. 初识IntPtr

    一:什么是IntPtr 先来看看MSDN上说的:用于表示指针或句柄的平台特定类型.这个其实说出了这样两个事实,IntPtr 可以用来表示指针或句柄.它是一个平台特定类型.对于它的解释,这个哥们写的比较 ...

  4. Node.js构建可扩展的Web应用1

    <Practical Node.js:Building Real-World Scalable Web Apps>[美]Azat Mardan(电子工业出版社) 安装node.js和NPM ...

  5. [javaSE] 基本类型(String相关)

    字符串是一个特殊的对象 字符串一旦初始化就不可以被改变 获取字符串的长度 调用String对象的length()方法,返回int长度 获取某个索引位置的字符 调用String对象的charAt()方法 ...

  6. java性能监控工具jstat

    jstat Monitors Java Virtual Machine (JVM) statistics. This command is experimental and unsupported. ...

  7. Unix 高手的10个好习惯

    引言 当您经常使用某个系统时,往往会陷入某种固定的使用模式.有时,您没有养成以尽可能最好的方式做事的习惯.有时,您的不良习惯甚至会导致出现混乱.纠正此类缺点的最佳方法之一,就是有意识地采用抵制这些坏习 ...

  8. 【学习笔记】--- 老男孩学Python,day14 python内置函数大全

    参考:  https://www.cnblogs.com/pyyu/p/6702896.html http://www.runoob.com/python3/python3-built-in-func ...

  9. PS改变图像颜色

    由于写的一个页面主色调变了,里面的一些图标颜色也要相应改变,自己难得重新去psd里面截图,就想着用ps,看能否直接能变换一下图标颜色.其实方法也很简单的. 1:用ps打开需要改变图标颜色的文件,然后选 ...

  10. 【Kendo UI系列开发使用笔记】01-简单介绍

    ps:接触telerik出品的kendo ui系列已经快有一年了,使用过程中也在不断踩坑填坑.这套UI用起来还是非常爽的,尤其asp.net mvc版的配合lambda表达式来配置参数非常流畅.这次对 ...