题意:给n个值, Q次询问, 每次询问给定一个区间, 要求输出该区间最大最小值之差

思路:暴力的话每次询问都要遍历多次for循环一定会超时, 用线段树记录区间的信息(左边界右边界, 该区间最大值最小值)

代码:

 #include<stdio.h>
#include<algorithm>
#define inf 0x3f3f3f3f
using namespace std; int n, m, arr[];
int ansmax, ansmin; struct Tree
{
int maxx, minn, left, right; //记录区间信息
}tree[ * ]; //开四倍空间 void build(int left, int right, int k)
{
tree[k].left = left, tree[k].right = right; //区间左右
if(tree[k].left == tree[k].right)
{
tree[k].maxx = tree[k].minn = arr[left]; //分到最后只剩下一个值 记为最大最小值
return ;
}
int mid = (left + right)/;
build(left, mid, k * ); //往左右儿子构造线段树
build(mid + , right, k * + );
tree[k].maxx = max(tree[k * ].maxx, tree[k * + ].maxx); //满足区间相加.子区间之间的最大最小值也是父亲区间的最大最小值
tree[k].minn = min(tree[k * ].minn, tree[k * + ].minn);
} void query(int k, int left, int right, int find_left, int find_right)
{ //如果ansmax已经大于等于该点区间最大值,ansmin已经小于等于该点区间最小值 , 不用更新,return
if(ansmax >= tree[k].maxx && ansmin <= tree[k].minn)
return ;
if(find_left == left && find_right == right)
{ //查询区间刚好是某个节点的区间, 该区间已经记录了最大最小值信息,可以直接调用并return
ansmax = max(ansmax, tree[k].maxx);
ansmin = min(ansmin, tree[k].minn);
return ;
}
int mid = (left + right)/;
if(find_right <= mid) //查询区间全位于该节点的左儿子区间
query( * k, left, mid, find_left, find_right);
else if(find_left > mid)//查询区间全位于该节点的右儿子区间
query( * k + , mid + , right, find_left, find_right);
else
{ //有位于左儿子和右儿子部分
query( * k, left, mid, find_left, mid);
query( * k + , mid + , right, mid + , find_right);
}
} int main()
{
int a, b;
scanf("%d%d", &n, &m);
for(int i = ; i <= n; i ++)//线段树根节点从1开始 ,数组从1开始存
scanf("%d", &arr[i]);
build(, n, );
for(int i = ; i <= m; i ++)
{
ansmax = -inf;
ansmin = inf;
scanf("%d%d", &a, &b);
query(, , n, a, b);
printf("%d\n", ansmax - ansmin);
}
return ;
}

POJ 3264 线段树入门解题报告的更多相关文章

  1. HDU 1754 线段树入门解题报告

    ---恢复内容开始--- 题意:给定区间,每个人的成绩, Q次询问,求每次询问区间中的最大值 思路:构造线段树 代码: #include<stdio.h> #include<algo ...

  2. POJ——3264线段树

    题目: 输入两个数(m,n),m表示牛的头数,n表示查询的个数.查询时输入两个数(x,y),表示查询范围的起始值和终止值,查询结果是,这个区间内牛重量的最大值减去牛重量的最小值,数量级为1000,00 ...

  3. poj 3264 线段树 求区间最大最小值

    Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the same ...

  4. POJ - 3264 线段树模板题 询问区间最大最小值

    这是线段树的一个模板题,给出一串数字,然后询问区间的最大最小值. 这个其实很好办,只需把线段树的节点给出两个权值,一个是区间的最小值,一个是区间的最大值,初始化为负无穷和正无穷,然后通过不断地输入节点 ...

  5. [NOIP2016 DAY1 T2]天天爱跑步-[差分+线段树合并][解题报告]

    [NOIP2016 DAY1 T2]天天爱跑步 题面: B[NOIP2016 DAY1]天天爱跑步 时间限制 : - MS 空间限制 : 565536 KB 评测说明 : 2s Description ...

  6. poj 3264 线段树

    题目意思:给定Q(1<=Q<=200000)个数A1,A2,```,AQ, 多次求任一区间Ai-Aj中最大数和最小数的差 线段树太弱了,题目逼格一高连代码都读不懂,今天开始重刷线段树,每天 ...

  7. 洛谷 P3373 【模板】线段树 2 解题报告

    P3373 [模板]线段树 2 题目描述 如题,已知一个数列,你需要进行下面三种操作: 1.将某区间每一个数乘上\(x\) 2.将某区间每一个数加上\(x\) 3.求出某区间每一个数的和 输入输出格式 ...

  8. POJ 3264 线段树 ST

    题意:给你一个数列,从中挑一段,问你这段数的最大值减最小值是多少. 思路:线段树. // by Sirius_Ren #include <cstdio> #include <algo ...

  9. G - Balanced Lineup POJ - 3264 线段树最大最小值区间查询模版题

    题意 给出一个序列  每次查询区间的max-min是多少 思路:直接维护max 和min即可  写两个query分别查最大最小值 #include<cstdio> #include< ...

随机推荐

  1. 基于Kafka的生产者消费者消息处理本地调试

    (尊重劳动成果,转载请注明出处:http://blog.csdn.net/qq_25827845/article/details/68174111冷血之心的博客) Kafka下载地址:http://d ...

  2. 【Shiro】小读Shiro Filter

    类继承结构图 看不明白此图不要紧,后面慢慢提到此图的类: AbstractFilter,抽象过滤器 它实现Filter.继承ServletContextSupport. 它主要实现了init(Filt ...

  3. Elasticsearch常用配置及性能参数[转]

    cluster.name: estest   集群名称node.name: “testanya”  节点名称 node.master: false  是否主节点node.data: true   是否 ...

  4. CentOS 7下PXE+Kickstart无人值守安装操作系统

    1.简介 1.1. 什么是PXE PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支 ...

  5. 【转】wpf 模板选择器DataTemplateSelector及动态绑定,DataTemplate.Triggers触发器的使用

    通常,如果有多个 DataTemplate 可用于同一类型的对象,并且您希望根据每个数据对象的属性提供自己的逻辑来选择要应用的 DataTemplate,则应创建 DataTemplateSelect ...

  6. SFTP工具类

    1.SFTP搭建方法: 地址: http://www.jb51.net/article/101405.htm https://blog.csdn.net/helloloser/article/deta ...

  7. Python学习笔记——发邮件

    参考:Python3实现163邮箱SMTP发送邮件 1.首先需要注册一个网易的邮箱,开启smtp服务,并使用其授权码 2.发送邮件的Python脚本 #!/usr/bin/python # -*- c ...

  8. .net读取Excel转datatable、.net读取的Excel存在合并单元格并且转成datatable

    项目中经常会遇到Excel导入数据,Excel的模板会可能是存在合并单元格的,模板如下图所示 读取时需要填充合并单元格的值,转成datatable单元格值时,填充合并单元格的值,如下图所示: 合并单元 ...

  9. SQUAD的rnet复现踩坑记

    在港科大rnet(https://github.com/HKUST-KnowComp/R-Net) 实现的基础上做了复现 采用melt框架训练,原因是港科大实现在工程上不是很完美,包括固定了batch ...

  10. Cocos2dx项目在各种IDE中新建类之后的可行编译方式

    注:这里说可行,但是并不是最好的,只是可以完成编译. 1.linux+code::blocks下的cocos2dx项目新建一个类TestScene.h 新建的TestScene.h和TestScene ...