题目描述

YYH擅长种竹子。今天他收获了一根竹子,准备将这根柱子卖给CHS。这个竹子有n-1个竹节。CHS要求一定要从竹节的地方砍,而且砍成若干段后每一段竹子中最长的一小段竹子和最短的一小段的长度差不能超过s,一段竹子至少含有l小段竹子。这可让YYH郁闷了,他希望留点力气刷题,所以他想知道他最少可以将整根竹子砍成多少段。

输入输出格式

输入格式:

输入第一行三个整数,n,s,l,意义如题目所描述

输入第二行n个整数,a[1],a[2],……,a[n],分别为每小段竹子的长度

输出格式:

如果有满足条件的砍法,输出整根竹子砍成最少的段数。否则输出-1

这道题我们很显然要用DP来做。

那么首先我们需要构造出一个DP方程

f[i]肯定由另一个状态dp转移后+1得到,那么这个状态是什么呢?

很明显就是mint[i]~i-k(在此mint表示的是以i为结尾的竹子最左端最多能延展到的位置)

看到这个之后我们想到了一个N^2DP

但是还是不够

我们想一想如何得到mint?

mint就是判断一段区间的最大值减去最小值是否满足题意

那么我们可不可以用数据结构得出这个答案呢?

显然我们可以用线段树来优化这个过程

时间复杂度O(nlogn)

同样在得出答案的过程我们也可以用线段树加速

下面贴代码

#include<cstdio>
#include<cstring>
#define inf 0x3f3f3f3f
#define min(x,y) (x<y?x:y)
#define max(x,y) (x>y?x:y)
using namespace std;
int a[];
struct mm{
int v1,v2;
}t[];
int mint[];
int f[];
int m=,n,s,l;
void pushdown(int i){t[i].v1=min(t[i<<].v1,t[i<<|].v1);t[i].v2=max(t[i<<].v2,t[i<<|].v2);}
void buildtree(){
while(m<n+)m<<=;
for(int i=;i<=n;i++)
t[i+m].v1=t[i+m].v2=a[i];
for(int i=m-;i;i--)
pushdown(i);
}
int query(int l,int r)
{
int maxn=-inf,minn=inf;
for(l=l+m-,r=r+m+;l^r^;l>>=,r>>=)
{
if(~l&)minn=min(minn,t[l^].v1),maxn=max(maxn,t[l^].v2);
if(r&)minn=min(minn,t[r^].v1),maxn=max(maxn,t[r^].v2);
}
return maxn-minn;
}
int que(int l,int r)
{
int minn=inf;
for(l+=m-,r+=m+;l^r^;l>>=,r>>=)
{
if(~l&)minn=min(minn,f[l^]);
if(r&)minn=min(minn,f[r^]);
}
return minn;
}
void push(int x){f[x]=min(f[x<<],f[x<<|]);}
void add(int x,int y){for(f[x+=m]=y,x>>=;x;x>>=)push(x);}
int main(){
memset(f,/,sizeof(f));
scanf("%d%d%d",&n,&s,&l);n++;
for(int i=;i<=n;i++)scanf("%d",&a[i]);
a[]=a[];
buildtree();
int le=;
for(int i=;i<=n;i++)
{
int tmp=query(le,i);
while(tmp>s)
{
tmp=query(++le,i);
}
mint[i]=le;
}
add(,);
for(int i=;i<=n;i++)
if(max(,mint[i]-)>i-l)add(i,inf);
else add(i,que(max(,mint[i]-),i-l)+);
printf("%d\n",f[n+m]>=inf?-:f[n+m]);
return ;
}

YYH的苍天大竹(NOIP模拟赛Round 6)的更多相关文章

  1. YYH的积木(NOIP模拟赛Round 6)

    题目描述 YYH手上有n盒积木,每个积木有个重量.现在他想从每盒积木中拿一块积木,放在一起,这一堆积木的重量为每块积木的重量和.现在他想知道重量最少的k种取法的重量分别是多少. 输入输出格式 输入格式 ...

  2. YYH的王国(NOIP模拟赛Round 6)

    题目描述 YYH拥有一个有n个城市的国家,编号为1~n.其中城市i到城市j的路径长度为i和j的最小公倍数.现在YYH想建一些高速公路,使得任意两座城市都能通过高速公路直接或间接到达.建造一条高速公路的 ...

  3. YYH算组合数(NOIP模拟赛Round 6)

    题目描述 YYH手上有一个长度为N的数列,而且这个数列正好能表示为.现在他想知道这个数列的最大公约数是多少,请你帮帮他 输入输出格式 输入格式: 每个数据点包括多组数据,以EOF结束 对于每个数据输入 ...

  4. YYH的营救计划(NOIP模拟赛Round 6)

    题目描述 “咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!YYH感动的热泪盈眶,开起了门…… YYH的父亲下班回家,街坊邻居说YYH被一群陌生人强行押上了警车!YYH的父 ...

  5. YYH的球盒游戏(NOIP模拟赛Round 6)

    题目描述 YYH有一些总共有种颜色的球,他有颜色的球个.他同样有个盒子,第个盒子能放个球. 他的目标是把这个球按规则放进个盒子里: 对于一个盒子,对于每种颜色的球至多只能放个. 把颜色为的球放进盒子, ...

  6. 水(NOIP模拟赛Round #10)

    题目描述: 小Z有一个长度为的数列.他有次令人窒息的操作,每次操作可以使某个数字或.他当然是希望这些数字的乘积尽量小了.为了简化题目,你只需输出操作完成后的数列即可. ———————————————— ...

  7. 小红帽的画笔(NOIP模拟赛Round 7)

    又到了神奇的模拟赛时间~ 真是丧~ 好吧我们来看看题目 小红帽是Pop star上最著名的人类画家,她可以将任何画出的东西变成真实的物品.赋予她这样神奇能力的正是她手上的画笔. 小红帽每次作画时,都需 ...

  8. 题(NOIP模拟赛Round #10)

    题目描述: 有一张的地图,其中的地方是墙,的地方是路.有两种操作: 给出个地点,询问这个地点中活动空间最大的编号.若询问的位置是墙,则活动空间为:否则活动空间为询问地点通过四联通能到达的点的个数.如果 ...

  9. 大(NOIP模拟赛Round #10)

    题目描述: 小Z有个n个点的高清大图,每个点有且只有一条单向边的出边.现在你可以翻转其中的一些边,使他从任何一个点都不能通过一些道路走回这个点.为了方便,你只需输出方案数对取模即可.当在两个方案中有任 ...

随机推荐

  1. python pycharm2018开启debug模式

    为什么需要开启DEBUG模式1.如果开启了DEBUG模式,那么在代码中如果抛出了异常,在浏览器的页面中可以看到具体的错误信息,以及具体的错误代码位置,方便开发者调试.2.如果开启DEBUG模式,那么以 ...

  2. Visual Stutio 2015激活密钥

    Visual Stutio 2015 专业版激活密钥:HMGNV-WCYXV-X7G9W-YCX63-B98R2 Visual Stutio 2015 企业版激活密钥:HM6NR-QXX7C-DFW2 ...

  3. C语言数组篇(三)字符空间 和 非字符空间

     一维数组和字符串         首先是字符数组(区别字符串) ] = {'a','b','c'}; //这只是单纯的字符数组,不是字符串          字符串最重要的标志就是结尾有一个'\0' ...

  4. 裸机——ADC

    1.首先是ADC的基本知识 模拟信号,连续的 数字信号,离散的 模拟信号,现实世界的很多东西都是连续的,所以使用模拟信号才能准确描述,但是模拟信号不方便控制. 数字信号,计算机中的信号大都为数字的,数 ...

  5. 单源次短路径:poj:3255-Roadblocks

    Roadblocks Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 17521 Accepted: 6167 Descripti ...

  6. python使用网易邮箱发邮件

    # -*- coding: UTF-8 -*- import smtplib from email.mime.text import MIMEText import email.mime.multip ...

  7. scala高级性质-隐式转换 -02

    今天我们来介绍scala的高级特性,上次已经介绍过他的一个特性:高阶函数,这次是隐式转换 1.隐式转换的例子 read的例子 解析:发现这个file没有read的方法,然后就开始在开始在这个上下文里面 ...

  8. WPF系列教程——(三)使用Win10 Edge浏览器内核 - 简书

    原文:WPF系列教程--(三)使用Win10 Edge浏览器内核 - 简书 在需要显示一些 H5网站的时候自带的WebBrowser总是显示不了,WebBrowser使用的是IE内核,许多H5新特性都 ...

  9. getprop 与 dumpsys 命令

    Android 设备连接 PC 后,我们可以通过 adb 命令完成绝大多数工作.下面借助 getprop.dumpsys 来了解一些系统相关信息. 一.getprop 此命令的原理很简单,就是从系统的 ...

  10. PowerShell脚本授权最佳实践

    [TechTarget中国原创] Windows PowerShell已成为微软在Windows Server上提供的首选管理界面.因为深度整合到Windows Server操作系统,PowerShe ...