YYH的苍天大竹(NOIP模拟赛Round 6)
题目描述
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)的更多相关文章
- YYH的积木(NOIP模拟赛Round 6)
题目描述 YYH手上有n盒积木,每个积木有个重量.现在他想从每盒积木中拿一块积木,放在一起,这一堆积木的重量为每块积木的重量和.现在他想知道重量最少的k种取法的重量分别是多少. 输入输出格式 输入格式 ...
- YYH的王国(NOIP模拟赛Round 6)
题目描述 YYH拥有一个有n个城市的国家,编号为1~n.其中城市i到城市j的路径长度为i和j的最小公倍数.现在YYH想建一些高速公路,使得任意两座城市都能通过高速公路直接或间接到达.建造一条高速公路的 ...
- YYH算组合数(NOIP模拟赛Round 6)
题目描述 YYH手上有一个长度为N的数列,而且这个数列正好能表示为.现在他想知道这个数列的最大公约数是多少,请你帮帮他 输入输出格式 输入格式: 每个数据点包括多组数据,以EOF结束 对于每个数据输入 ...
- YYH的营救计划(NOIP模拟赛Round 6)
题目描述 “咚咚咚……”“查水表!”原来是查水表来了,现在哪里找这么热心上门的查表员啊!YYH感动的热泪盈眶,开起了门…… YYH的父亲下班回家,街坊邻居说YYH被一群陌生人强行押上了警车!YYH的父 ...
- YYH的球盒游戏(NOIP模拟赛Round 6)
题目描述 YYH有一些总共有种颜色的球,他有颜色的球个.他同样有个盒子,第个盒子能放个球. 他的目标是把这个球按规则放进个盒子里: 对于一个盒子,对于每种颜色的球至多只能放个. 把颜色为的球放进盒子, ...
- 水(NOIP模拟赛Round #10)
题目描述: 小Z有一个长度为的数列.他有次令人窒息的操作,每次操作可以使某个数字或.他当然是希望这些数字的乘积尽量小了.为了简化题目,你只需输出操作完成后的数列即可. ———————————————— ...
- 小红帽的画笔(NOIP模拟赛Round 7)
又到了神奇的模拟赛时间~ 真是丧~ 好吧我们来看看题目 小红帽是Pop star上最著名的人类画家,她可以将任何画出的东西变成真实的物品.赋予她这样神奇能力的正是她手上的画笔. 小红帽每次作画时,都需 ...
- 题(NOIP模拟赛Round #10)
题目描述: 有一张的地图,其中的地方是墙,的地方是路.有两种操作: 给出个地点,询问这个地点中活动空间最大的编号.若询问的位置是墙,则活动空间为:否则活动空间为询问地点通过四联通能到达的点的个数.如果 ...
- 大(NOIP模拟赛Round #10)
题目描述: 小Z有个n个点的高清大图,每个点有且只有一条单向边的出边.现在你可以翻转其中的一些边,使他从任何一个点都不能通过一些道路走回这个点.为了方便,你只需输出方案数对取模即可.当在两个方案中有任 ...
随机推荐
- Makefile (1) gcc基础
.c(源文件) --> .i(预处理文件) -->.s(汇编文件) --> -o(目标文件) -->可执行文件 .c --预处理-->.i .i --编译--> ...
- c++右值引用
右值 右值是相对与左值来说的. 左值是以变量的形式存在,指向一个指定的内存,可以对它取地址.右值就是不指向任何地方,它是暂时和短命的,不能对它取地址. 右值引用 把临时的.生命周期短的值,绑定到一个变 ...
- 第一章 UNIX 基础知识
1.1 Unix体系结构 OS定义为一种软件,它控制计算机硬件资源,提供程序运行环境,一般称其为内核(kernel),它体积小,位于环境中心. 内核的接口为系统调用(system call),共用函数 ...
- Snowflake Snow Snowflakes【Poj3349】
Description You may have heard that no two snowflakes are alike. Your task is to write a program to ...
- 笔记-falsk-入门-1
笔记-falsk-入门-1 1. 前言 有几个概念需要解释下,WSGI,JINJA2,WERKZEUG Flask是典型的微框架,作为Web框架来说,它仅保留了核心功能:请求响应处理和模板渲 ...
- impala presto SparkSql性能测试对比
目标是为测试impala presto SparkSql谁的性能更佳,以下结果底层查询的都是普通textfile snappy压缩后数据,规模为15台机器,若以orcfile.parquet速度能 ...
- Ubuntu14.0.4系统如何获取root权限
Ubuntu14.0.4系统如何获取root权限 | 浏览:9684 | 更新:2014-08-21 10:38 7 分步阅读 本文主要讲解如何简单实用命令获取root权限 工具/原料 Ubuntu1 ...
- 剑指Offer - 九度1362 - 左旋转字符串(Move!Move!!Move!!!)
剑指Offer - 九度1362 - 左旋转字符串(Move!Move!!Move!!!)2013-11-23 03:05 题目描述: 汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任 ...
- 【Linear Support Vector Machine】林轩田机器学习技法
首先从介绍了Large_margin Separating Hyperplane的概念. (在linear separable的前提下)找到largest-margin的分界面,即最胖的那条分界线.下 ...
- leetcode 【 Linked List Swap Nodes in Pairs 】 python 实现
题目: Swap Nodes in Pairs Given a linked list, swap every two adjacent nodes and return its head. For ...