POJ3264——Balanced Lineup(线段树)
本文出自:http://blog.csdn.net/svitter
题意:在1~200,000个数中。取一段区间。然后在区间中找出最大的数和最小的数字。求这两个数字的差。
分析:按区间取值,非常明显使用的线段树。
区间大小取200000 * 4 = 8 * 10 ^5;
进行查询的时候。注意直接推断l, r 与mid的关系就可以。一開始写的时候直接与tree[root].L推断,多余了,
逻辑不对。
#include <iostream>
#include <stdio.h>
#include <stdlib.h> using namespace std;
const int INF = 0xffffff;
int maxV, minV; struct Node
{
int L, R;
int Mid(){ return (L+R)/2;}
int maxV, minV; //最大数和最小数
//Node *lchild, *rchild; 使用一位数组就能够不使用,能够看做全然二叉树(可能存在空间浪费)
}; Node tree[800010]; //四倍叶子节点 void Insert(int root, int n, int val)
{
//推断叶子节点
if(tree[root].L == tree[root].R)
{
tree[root].maxV = tree[root].minV = val;
return;
} //递归更新
tree[root].minV = min(tree[root].minV, val);
tree[root].maxV = max(tree[root].maxV, val); //当前为区间节点,寻找叶子节点
if(n < tree[root].Mid())
{
Insert(root*2+1, n, val);
}
else
{
Insert(root*2+2, n, val);
}
} void BuildTree(int root, int l, int r)
{
//建立当前节点
tree[root].L = l;
tree[root].R = r;
tree[root].maxV = -INF;
tree[root].minV = INF;
//递归调用建立子树
if(l != r)
{
BuildTree(root*2+1, l, (l+r)/2);
BuildTree(root*2+2, (l+r)/2+1, r);
} } void Query(int root, int l, int r)
{
//递归终止条件
if(l < tree[root].L || r > tree[root].R)
return; //推断条件:全然符合区间
if(l == tree[root].L && r == tree[root].R)
{
maxV = max(maxV, tree[root].maxV);
minV = min(minV, tree[root].minV);
return;
} if(r <= tree[root].Mid())
Query(root*2+1, l, r);
else if(l > tree[root].Mid())
Query(root*2+2, l, r);
else
{
Query(root*2+1, l, tree[root].Mid());
Query(root*2+2, tree[root].Mid()+1, r);
}
} int main()
{
int N, Q;
int val;
int a, b; //查找区间[a,b]
//while(scanf("%d%d", &N, &Q))
scanf("%d%d", &N, &Q);
{ BuildTree(0, 1, N);
for(int i = 0; i < N; i ++)
{
scanf("%d", &val);
Insert(0, i, val);
}
//用于測试线段树生成情况
// for(int i = 0; i < 7; i++)
// {
// printf("No:%d,\nL: %d,\nR: %d,\nMAX: %d,\nMIN: %d,\n\n", i, tree[i].L, tree[i].R, tree[i].maxV, tree[i].minV);
// }
while(Q--)
{
maxV = -INF, minV = INF;
scanf("%d%d", &a, &b);
Query(0, a, b);
// printf("max: %d\nmin: %d\n", maxV, minV);
printf("%d\n", maxV - minV);
}
} return 0;
}
POJ3264——Balanced Lineup(线段树)的更多相关文章
- POJ3264 Balanced Lineup —— 线段树单点更新 区间最大最小值
题目链接:https://vjudge.net/problem/POJ-3264 For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000 ...
- POJ3264 Balanced Lineup 线段树区间最大值 最小值
Q个数 问区间最大值-区间最小值 // #pragma comment(linker, "/STACK:1024000000,1024000000") #include <i ...
- BZOJ-1699 Balanced Lineup 线段树区间最大差值
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 41548 Accepted: 19514 Cas ...
- [POJ] 3264 Balanced Lineup [线段树]
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34306 Accepted: 16137 ...
- 【POJ】3264 Balanced Lineup ——线段树 区间最值
Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 34140 Accepted: 16044 ...
- bzoj 1636: [Usaco2007 Jan]Balanced Lineup -- 线段树
1636: [Usaco2007 Jan]Balanced Lineup Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 772 Solved: 560线 ...
- poj3264 Balanced Lineup(树状数组)
题目传送门 Balanced Lineup Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 64655 Accepted: ...
- POJ 3264 Balanced Lineup 线段树 第三题
Balanced Lineup Description For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line ...
- poj 3264 Balanced Lineup(线段树、RMQ)
题目链接: http://poj.org/problem?id=3264 思路分析: 典型的区间统计问题,要求求出某段区间中的极值,可以使用线段树求解. 在线段树结点中存储区间中的最小值与最大值:查询 ...
- POJ 3264 Balanced Lineup (线段树)
Balanced Lineup For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) always line up in the s ...
随机推荐
- C#复习二(Twenty First Day)
呵呵,又来到了今天的总结.这次主要复习了一下字符串的一些处理.今天就来总结一下. 理论: String 字符串,字符串可以看成字符数组,不可变特性(通过for循环,修改string中的元素,失败!) ...
- Java学习之内部类
示例1: package com.swust.面向对象; class Person1{ private String username="zhangsan"; public Per ...
- Arduino 时钟模块(clock module) DS1306
http://www.pjrc.com/teensy/td_libs_DS1307RTC.html 下载相关的库程序 连接: DS1306: 1.接3.3V 2.SDA接A4 3.SCL接A5 读取: ...
- python自学笔记(四)python基本数据类型之元组、集合、字典
一.元组tuple 特性 1.有序集合 2.通过偏移来取数据 3.不可变对象,不能在原地修改内存,没有排序.修改等操作 元组不可变的好处:保证数据的安全,比如我们传给一个不熟悉的方法,确保不会改变我们 ...
- HTTP使用BASIC认证的原理及实现方法 (转载)
转自:http://blog.itpub.net/23071790/viewspace-709367 一. BASIC认证概述 在HTTP协议进行通信的过程中,HTTP协议定义了基本认证过程以允许 ...
- SpringMVC之访问静态文件
我们在进行springMVC开发时,必定会在jsp页面引入js文件.img文件和css文件.大多数人会将这些分类存放在WebRoot文件下新建的文件夹下面.同时,会在web.xml文件中配置拦截所有请 ...
- 数据结构之后缀数组suffix array
在字符串处理当中,后缀树和后缀数组都是非常有力的工具,其中后缀树大家了解得比较多,关于后缀数组则很少见于国内的资料.其实后缀是后缀树的一个非常精巧的替代品,它比后缀树容易编程实现,能够实现后缀树的很多 ...
- 宣布发布 Windows Azure 导入/导出服务的预览版以及 Web 和移动解决方案场景的若干增强功能
客户评估基于云的存储解决方案时,面临的挑战之一是以经济高效.安全快速的方式从 Blob 存储区移进和移出大量数据.今天,我们很高兴地宣布发布 Windows Azure 导入/导出的预览版,这款新服务 ...
- 过拟合/欠拟合&logistic回归等总结(Ng第二课)
昨天学习完了Ng的第二课,总结如下: 过拟合:欠拟合: 参数学习算法:非参数学习算法 局部加权回归 KD tree 最小二乘 中心极限定律 感知器算法 sigmod函数 梯度下降/梯度上升 二元分类 ...
- leetcode_question_67 Add Binary
Given two binary strings, return their sum (also a binary string). For example, a = "11" b ...