POJ3264:Balanced Lineup——题解+st表解释
我早期在csdn的博客之一,正好复习st表就拿过来。
http://write.blog.csdn.net/mdeditor#!postId=63713810
这道题其实本身不难(前提是你得掌握线段树或者st表当中的一种)
那么这道题我们来讲一讲st表(因为这题询问次数有点多)
一般关系式
dp[i][j]=min/max(dp[dp[i][j-1],dp[i+pow(2,j-1)][j-1]])
可以看出来吧,其实这就是动态规划
好的我们来解释一下关系式是什么吧
首先这个是一个二分,具体是什么呢:
其中的i代表起点,2^j代表起点到中点的长度。
如果还不懂的话,我们来看一下样例(求最小值)
2 6 4 8 9 7 11
好的,我们来模拟一下程序的运作
dp[1][0]=2;dp[2][0]=6……dp[7][0]=11;
然后dp[1][1]=min(2,6)=2; dp[3][1]=min(4,8)=4;……dp[6][1]=min(7,11)=7;
再然后dp[1][2]=min(2,4)=2;……
如此这般如此这般
怎么样,给一个样例是不是就很清楚了。
然后就是查询了,但是有时候因为查询区间比较大,没办法一步到位怎么办
例如查询1-5的区间,然而按照我们上面的定义来的话,我们最大可以调用dp[1][2],然而却落了第五个点。
其实很简单,结果=min(dp[1][2],dp[2][2])
原因也无需解释了吧
那么我们用代码实现吧,顺便把这道题写了吧
#include<cstdio>
#include<cmath>
#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
int maxn[][],minn[][];
int qpow(int a){
return (<<a);
}
void st(int n){
for(int j=;j<=int(log2(n));j++){
for(int i=;i<=n;i++){
int p=i+pow(,j)-;
if(p>n)continue;
maxn[i][j]=max(maxn[i][j-],maxn[i+int(qpow(j-))][j-]);
minn[i][j]=min(minn[i][j-],minn[i+int(qpow(j-))][j-]);
}
}
return;
}
int main(){
int n,q,k,x,y;
scanf("%d%d",&n,&q);
for(int i=;i<=n;i++){
scanf("%d",&maxn[i][]);
minn[i][]=maxn[i][];
}
st(n);
for(int i=;i<=q;i++){
scanf("%d%d",&x,&y);
if(y<x){
int t=x;x=y;y=t;
}
double s=y-x+;
int ke=log2(s);
int he=qpow(int(log2(s)));
int t1=max(maxn[x][int(log2(s))],maxn[y-he+][ke]);
int t2=min(minn[x][int(log2(s))],minn[y-he+][ke]);
printf("%d\n",t1-t2);
}
return ;
}
POJ3264:Balanced Lineup——题解+st表解释的更多相关文章
- 【洛谷】P2880 [USACO07JAN]平衡的阵容Balanced Lineup(st表)
题目背景 题目描述: 每天,农夫 John 的N(1 <= N <= 50,000)头牛总是按同一序列排队. 有一天, John 决定让一些牛们玩一场飞盘比赛. 他准备找一群在对列中为置连 ...
- POJ 3264 Balanced Lineup 【ST表 静态RMQ】
传送门:http://poj.org/problem?id=3264 Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total S ...
- 洛谷 P2880 [USACO07JAN]Balanced Lineup G (ST表模板)
题意:给你一组数,询问\(q\)次,问所给区间内的最大值和最小值的差. 题解:经典RMQ问题,用st表维护两个数组分别记录最大值和最小值然后直接查询输出就好了 代码: int n,q; int a[N ...
- Luogu P2880 [USACO07JAN]平衡的阵容Balanced Lineup (ST表模板)
传送门(ST表裸题) ST表是一种很优雅的算法,用于求静态RMQ 数组l[i][j]表示从i开始,长度为2^j的序列中的最大值 注意事项: 1.核心部分: ; (<<j) <= n; ...
- [POJ3264]Balanced Lineup(RMQ, ST算法)
题目链接:http://poj.org/problem?id=3264 典型RMQ,这道题被我鞭尸了三遍也是醉了…这回用新学的st算法. st算法本身是一个区间dp,利用的性质就是相邻两个区间的最值的 ...
- poj3264 - Balanced Lineup(RMQ_ST)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 45243 Accepted: 21240 ...
- POJ3264 Balanced Lineup
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 44720 Accepted: 20995 ...
- poj 3264 Balanced Lineup 题解
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536KB 64bit IO Format: %I64d & %I64u Subm ...
- poj3264Balanced Lineup(倍增ST表)
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 52328 Accepted: 24551 ...
随机推荐
- 这样的SQL居然能执行
select /*! distinct cities.id from cities join countries on cities.id = countries.id limit 10 */;
- 【廖雪峰老师python教程】——IO编程
同步IO 异步IO 最常见的IO——读写文件 读写文件前,我们先必须了解一下,在磁盘上读写文件的功能都是由操作系统提供的,现代操作系统不允许普通的程序直接操作磁盘,所以,读写文件就是请求操作系统打开一 ...
- Python Road
引子 雁离群兮不知所归,路遥远兮吾将何往 Python Road[第一篇]:Python简介 Python Road[第二篇]:Python基本数据类型 Python Road[第三篇]:Pyth ...
- 围绕DOM元素节点的增删改查
HTML 文档中的所有内容都是节点: 整个文档是一个文档节点 document 每个 HTML 元素是元素节点 element HTML 元素内的文本是文本节点 每个 HTML 属性是属性节点 注释是 ...
- Python全栈 正则表达式(re模块正则接口全方位详解)
re模块是Python的标准库模块 模块正则接口的整体模式 re.compile 返回regetx对象 finditer fullmatch match search 返回 match对象 match ...
- 【转】: 探索Lua5.2内部实现:虚拟机指令(2) MOVE & LOAD
name args desc OP_MOVE A B R(A) := R(B) OP_MOVE用来将寄存器B中的值拷贝到寄存器A中.由于Lua是register based vm,大部分的指令都是直接 ...
- 对Java对象的认识与理解
今天是我学习编程以来第一次写博客,记下平日学习所得,本来这几日都在学习web框架 但觉得梳理一下之前所学很有必要.毕竟之前学习Java感觉很粗略只是以考试为目的.所以就以<Thinking in ...
- 深入理解eos账户体系 active和action
在eos中,账户是一个非常重要的概念. 账户分为两部分组成 一种是active 一种是action. 智能合约本质上来讲就是一个action加上一个回馈脚本程序.任何智能合约都有这俩个部分组成. 那么 ...
- 哈希表 STL map
计数排序时我们使用一个数组来记录出现的数字的次数,而当数据范围太大时,无法建立一个那么大地数组(而且可能空间利用率很低,太浪费),此时可以改用hash table . binary search tr ...
- 最多水容器(M)
题目 给定n个非负整数a 1,a 2,...,a n,其中每个代表坐标(i,a i)处的一个点.绘制n条垂直线,使得线i的两个端点处于(i,a i)和(i,0)处.找到两条线,它们与x轴一起形成一个容 ...