【POJ No. 3264】区间最值差 Balanced Lineup
创始人
2024-03-16 15:50:39

【POJ No. 3264】区间最值差 Balanced Lineup

北大OJ 题目地址

在这里插入图片描述

其实这道题 之前也做过一次了

http://t.csdn.cn/0YZgC

在这里插入图片描述

不过上次是用ST 做的。这次换做 分块来实现。

【题意】

每天挤奶时,约翰的N 头奶牛(1≤N≤50,000)都以相同的顺序排队。他挑选一系列连续的奶牛来玩游戏。

为了让所有奶牛都玩得开心,它们的高度差异不应太大。约翰列出了Q组(1≤Q ≤200,000)奶牛和它们的高度(1≤height≤1,000,000)。他希望确定每个小组中最高和最矮的奶牛之间的高度差异。

【输入输出】

输入:

第1行包含两个整数N 和Q 。接下来N 行,每行都包含一个整数,表示奶牛的高度。最后Q 行,每行都包含两个整数A 和B (1≤A≤B ≤N ),代表从A 到B 的奶牛范围。

输出:

输出Q 行,每行都包含一个整数,表示该范围内最高和最矮奶牛的高度差。

【样例】

在这里插入图片描述

【思路分析】

这道题是典型的区间最值查询问题,可采用线段树、ST或分块解决。

【算法设计】

① 分块。划分块,记录每个元素所属的块,以及每一块的左右端点下标、最大值和最小值。

② 查询。查询[l , r ]区间最大值和最小值的差值。

  • 若该区间属于同一块,则暴力统计最大值和最小值,返回两者的差值。
  • 若该区间包含多个块,则统计中间每个块的最大值和最小值,然后暴力统计左端点和右端点的最大值和最小值,返回两者的差值。

【算法实现】

#include
#include
#include//max,min
#include//sqrtusing namespace std;const int inf=0x3f3f3f3f;
const int maxn=50010;
int L[maxn],R[maxn],belong[maxn],block_max[maxn],block_min[maxn];
int a[maxn],n,m;void build(){int t=sqrt(n*1.0);int num=n/t;if(n%num) num++;for(int i=1;i<=num;i++)L[i]=(i-1)*t+1,R[i]=i*t;R[num]=n;for(int i=1;i<=n;i++)belong[i]=(i-1)/t+1;for(int i=1;i<=num;i++){//求每块最值 int MIN=inf,MAX=-inf;for(int j=L[i];j<=R[i];j++){MAX=max(MAX,a[j]);MIN=min(MIN,a[j]);		}block_max[i]=MAX;block_min[i]=MIN;	}
}int query(int l,int r){int MIN=inf,MAX=-inf;if(belong[l]==belong[r]){for(int i=l;i<=r;i++){MAX=max(MAX,a[i]);MIN=min(MIN,a[i]);	}return MAX-MIN;}else{for(int i=l;i<=R[belong[l]];i++){//左端MAX=max(MAX,a[i]);MIN=min(MIN,a[i]);	}for(int i=belong[l]+1;i//中间MAX=max(MAX,block_max[i]);MIN=min(MIN,block_min[i]);	}for(int i=L[belong[r]];i<=r;i++){//右端MAX=max(MAX,a[i]);MIN=min(MIN,a[i]);	}}return MAX-MIN;
}int main(){int l,r;while(~scanf("%d%d",&n,&m)){for(int i=1;i<=n;i++)//下标从1开始 scanf("%d",&a[i]);build();for(int j=1;j<=m;j++){scanf("%d%d",&l,&r);printf("%d\n",query(l,r));}}return 0;
}

在这里插入图片描述

相关内容

热门资讯

埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
埃菲尔铁塔在哪 中国仿建埃菲尔... 2019年4月26日,广西南宁市,街头惊现一座巨型山寨版埃菲尔铁塔,高约20米,白色塔身,造型逼真,...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...