士兵杀敌(三)

时间限制:2000 ms  |  内存限制:65535 KB
难度:5
描述

南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比较,计算出两个人的杀敌数差值,用这种方法一方面能鼓舞杀敌数高的人,另一方面也算是批评杀敌数低的人,起到了很好的效果。

所以,南将军经常问军师小工第i号士兵到第j号士兵中,杀敌数最高的人与杀敌数最低的人之间军功差值是多少。

现在,请你写一个程序,帮小工回答南将军每次的询问吧。

注意,南将军可能询问很多次。

输入
只有一组测试数据

第一行是两个整数N,Q,其中N表示士兵的总数。Q表示南将军询问的次数。(1<N<=100000,1<Q<=1000000)

随后的一行有N个整数Vi(0<=Vi<100000000),分别表示每个人的杀敌数。

再之后的Q行,每行有两个正正数m,n,表示南将军询问的是第m号士兵到第n号士兵。
输出
对于每次询问,输出第m号士兵到第n号士兵之间所有士兵杀敌数的最大值与最小值的差。
样例输入
5 2
1 2 6 9 3
1 2
2 4
样例输出
1
7

题目链接

很裸的线段树问题,树的结点里保存本区间里最大和最小值

#include<stdio.h>
typedef struct NODE
{
int max, min;
int start, end;
}Node;
Node tree[1211110];
int max, min;
void buildtree(int root, int start, int end)
{
tree[root].start = start;
tree[root].end = end;
tree[root].max = -0x7fffffff;
tree[root].min = 0x7fffffff;
if(start < end)
{
buildtree(root * 2, start, (start + end)/ 2);
buildtree(root * 2 + 1, (start + end) / 2 + 1, end);
}
}
void insert(int root, int pos, int num)
{ if(tree[root].max < num)
tree[root].max = num;
if(tree[root].min > num)
tree[root].min = num;
// if(tree[root].start == pos && tree[root].end == pos)
// return ;
if(tree[root].start < tree[root].end)
{
if(pos < (tree[root].start + tree[root].end) / 2 + 1)
insert(root * 2, pos, num);
else
insert(root * 2 + 1, pos, num);
}
}
void quest(int root, int start, int end)
{
if(tree[root].max <= max && tree[root].min >= min)
return ;
if(start == tree[root].start && end == tree[root].end )
{
max = max > tree[root].max ? max : tree[root].max;
min = min < tree[root].min ? min : tree[root].min;
return;
}
if(end < (tree[root].start + tree[root].end) / 2 + 1)
quest(root * 2, start, end);
else if(start >( tree[root].start + tree[root].end) / 2)
quest(root * 2 + 1, start, end);
else
{
quest(root * 2, start, (tree[root].start + tree[root].end) / 2);
quest(root * 2 + 1, (tree[root].start + tree[root].end) / 2 + 1, end);
}
}
int main()
{
int n, q;
scanf("%d %d", &n, &q);
buildtree(1, 1, n);
int i;
int num;
for(i = 1; i <= n; i++)
{
scanf("%d", &num);
insert(1, i, num);
}
int s, e;
for(i = 1; i <= q; i++)
{
scanf("%d%d", &s, &e);
max = -1;
min = 0x7fffffff;
quest(1, s, e);
printf("%d\n", max-min);
}
return 0;
}

POJ 3264-Balanced Lineup, NYOJ 119-士兵杀敌3 线段树的更多相关文章

  1. NYOJ 116 士兵杀敌 (线段树,区间和)

    题目链接:NYOJ 116 士兵杀敌 士兵杀敌(二) 时间限制:1000 ms  |  内存限制:65535 KB 难度:5 描写叙述 南将军手下有N个士兵,分别编号1到N,这些士兵的杀敌数都是已知的 ...

  2. NYOJ 119 士兵杀敌(三) RMQ ST

    NYOJ 119 士兵杀敌(三) RMQ ST 题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=119 思路: ST在线 预处理O(nlog ...

  3. Poj 3264 Balanced Lineup RMQ模板

    题目链接: Poj 3264 Balanced Lineup 题目描述: 给出一个n个数的序列,有q个查询,每次查询区间[l, r]内的最大值与最小值的绝对值. 解题思路: 很模板的RMQ模板题,在这 ...

  4. POJ 3264 Balanced Lineup 【ST表 静态RMQ】

    传送门:http://poj.org/problem?id=3264 Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total S ...

  5. poj 3264 Balanced Lineup (RMQ)

    /******************************************************* 题目: Balanced Lineup(poj 3264) 链接: http://po ...

  6. POJ 3264 Balanced Lineup【线段树区间查询求最大值和最小值】

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 53703   Accepted: 25237 ...

  7. POJ - 3264——Balanced Lineup(入门线段树)

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 68466   Accepted: 31752 ...

  8. poj 3264 Balanced Lineup 题解

    Balanced Lineup Time Limit: 5000MS   Memory Limit: 65536KB   64bit IO Format: %I64d & %I64u Subm ...

  9. poj 3264 Balanced Lineup 区间极值RMQ

    题目链接:http://poj.org/problem?id=3264 For the daily milking, Farmer John's N cows (1 ≤ N ≤ 50,000) alw ...

随机推荐

  1. JS对日期时间的操作

    代码: //判断是否超期(有效期开始超过一年后算已超期) function IsEffect(effectDate) { var val = ""; var currentDate ...

  2. Dynamics CRM4.0 和 Dynamics CRM2011 Plugin 实现一样的功能的方法的比较

    1.给类型赋值不同 CRM4 plugin给lookup赋值为空 : Lookup lookupnull = new Lookup(); lookupnull.IsNull = true; looku ...

  3. WinForm窗体拖动代码

    本文转载自:http://www.cnblogs.com/ap0606122/archive/2012/10/23/2734964.html using System; using System.Co ...

  4. 网页颜色RGB记法和16进制记法转化方法

    A=>10,B=>11,C=>12,D=>13,E=>14,F=>15 看一个例子: 254,112,85 255/16 等于 15 余 14 那么它对应的应该是F ...

  5. 在Visual Studio里配置及查看IL(转载)

    原文地址:http://www.myext.cn/other/a_25162.html 在之前的版本VS2010中,在Tools下有IL Disassembler(IL中间语言查看器),但是我想直接集 ...

  6. poj1160 post office

    题目大意:有n个乡村,现在要建立m个邮局,邮局只能建在乡村里.现在要使每个乡村到离它最近的邮局距离的总和尽量小,求这个最小距离和. n<300,p<30,乡村的位置不超过10000. 分析 ...

  7. Office导入导出组件权限配置汇总

    NET导出Excel遇到的80070005错误的解决方法: 检索 COM 类工厂中 CLSID 为 {00024500-0000-0000-C000-000000000046}的组件时失败,原因是出现 ...

  8. JS URL 使用base64加密与解密

    JS编码方式: <script type="text/javascript"> document.write(encodeURI("http://www.w3 ...

  9. Hadoop MapReduce编程学习

    一直在搞spark,也没时间弄hadoop,不过Hadoop基本的编程我觉得我还是要会吧,看到一篇不错的文章,不过应该应用于hadoop2.0以前,因为代码中有  conf.set("map ...

  10. Form_Form Builder Export导出为Excel(案例)

    2014-01-09 Created By BaoXinjian