题目链接

描述

南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战(编号相近的人经常在一块,相互之间比较熟悉),最终他们获得的军功,也将会平分到每个人身上,这样,有时候,计算他们中的哪一个人到底有多少军功就是一个比较困难的事情,军师小工的任务就是在南将军询问他某个人的军功的时候,快速的报出此人的军功,请你编写一个程序来帮助小工吧。

假设起始时所有人的军功都是0.

  • 输入

    只有一组测试数据。每一行是两个整数T和M表示共有T条指令,M个士兵。(1<=T,M<=1000000)随后的T行,每行是一个指令。指令分为两种:一种形如ADD 100 500 55 表示,第100个人到第500个人请战,最终每人平均获得了55军功,每次每人获得的军功数不会超过100,不会低于-100。第二种形如:QUERY 300 表示南将军在询问第300个人的军功是多少。
  • 输出

    对于每次查询输出此人的军功,每个查询的输出占一行。
  • 样例输入

    4 10

    ADD 1 3 10

    QUERY 3

    ADD 2 6 50

    QUERY 3
  • 样例输出

    10

    60

分析:

刚开始想到肯定要用线段树来写,然后用普通的线段树写,每次更新的时候从当前区间开始更新到最大区间,但是这样的话时间超,然后就像了一种优化点的方法

每次在更新的时候,只有找到这个特定的区间之后,才将该区间的value值加,不用向上加。然后在求值的时候每个包含该点的区间的value值都应该加上,因为他可能是通过任意一个区间去建立军功值的。

代码:

    #include<stdio.h>
#include<iostream>
#include<stack>
#include<string.h>
#include<stdlib.h>
#include<queue>
#include<algorithm>
using namespace std;
int e[10000]= {0};
int T,M;
struct Node
{
int left;
int right;
int value;
} tree[4000000+10]; void built(int root,int n1,int n2)///刚开始建树的时候,每个节点的军功值都是0
{
tree[root].left=n1;
tree[root].right=n2;
tree[root].value=0;
if(n1==n2)
return ;
int mid=(n1+n2)/2;
built(root*2,n1,mid);
built(root*2+1,mid+1,n2);
}
void UpDate(int root,int n1,int n2,int num)
{
if(tree[root].left==n1&&tree[root].right==n2)///找到特定的区间后才把该区间中的军功值加上,注意这里不用累计往上加
{
tree[root].value+=num;///也就是以为着这个区间上的每个人的军功值都加了value
return ;
}
if(n1>=tree[root*2+1].left)
{
UpDate(root*2+1,n1,n2,num);
}
else if(n2<=tree[root*2].right)
{
UpDate(root*2,n1,n2,num);
}
else
{
int mid=(tree[root].left+tree[root].right)/2;
UpDate(root*2,n1,mid,num);
UpDate(root*2+1,mid+1,n2,num);
}
} int Sum(int root,int n1,int sum)
{ sum+=tree[root].value;///因为在插入的时候只在特定的区间上加,所以只要找到包含这个点的区间,也就意味这该区间中有这个人的军功值
if(tree[root].left==n1&&tree[root].right==n1)
{
return sum;
}
else if(n1>=tree[root*2+1].left)
return (Sum(root*2+1,n1,sum));
else if(n1<=tree[root*2].right)
return (Sum(root*2,n1,sum));
}
int main()
{
scanf("%d%d",&T,&M);
char a[10];
int n1,n2,num;
built(1,1,M);
for(int i=0; i<T; i++)
{
scanf(" %s",a);
if(a[0]=='A')
{
scanf("%d%d%d",&n1,&n2,&num);
UpDate(1,n1,n2,num);
}
else
{
scanf("%d",&n1);
printf("%d\n",Sum(1,n1,0));
}
}
return 0;
}

NYOJ 123 士兵杀敌(四) (线段树)的更多相关文章

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

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

  2. nyoj 123 士兵杀敌(四) 树状数组【单点查询+区间修改】

    士兵杀敌(四) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战 ...

  3. POJ 3264-Balanced Lineup, NYOJ 119-士兵杀敌3 线段树

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进行比 ...

  4. NYOJ 123 士兵杀敌4-树状数组的插线求点

    士兵杀敌(四) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描述 南将军麾下有百万精兵,现已知共有M个士兵,编号为1~M,每次有任务的时候,总会有一批编号连在一起人请战(编 ...

  5. NYOJ 108 士兵杀敌1(树状数组)

    首先,要先讲讲树状数组: 树状数组(Binary Indexed Tree(BIT), Fenwick Tree)是一个查询和修改复杂度都为log(n)的数据结构.主要用于查询任意两位之间的所有元素之 ...

  6. nyoj 123 士兵杀敌(四)【树状数组】+【插线问点】

    树状数组有两种情况:插点问线和插线问点.这道题是插线问点. 由于树状数组最简单的作用是计算1~x的和,所以给出(a, b. c).表示(a,b)区间添加c, 那我们仅仅须要在a点原来的基础上添加c,然 ...

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

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

  8. nyoj 119 士兵杀敌(三)【线段树区间最大值最小值差】

    士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5   描述 南将军统率着N个士兵,士兵分别编号为1~N,南将军经常爱拿某一段编号内杀敌数最高的人与杀敌数最低的人进 ...

  9. nyoj 119士兵杀敌(三)(线段树区间最值查询,RMQ算法)

    题目119 题目信息 执行结果 本题排行 讨论区 士兵杀敌(三) 时间限制:2000 ms  |  内存限制:65535 KB 难度:5 描写叙述 南将军统率着N个士兵,士兵分别编号为1~N,南将军常 ...

随机推荐

  1. 性能测试问题_tomcat占用内存很高,响应速度很慢

    Cronolog 1.       问题描述 Tomcat占用服务器内存过大导致访问变慢 2.       问题原因 查看catalina.out文件过大,写日志时占用内存过大 3.       解决 ...

  2. HBase 架构与工作原理4 - 压缩、分裂与故障恢复

    本文系转载,如有侵权,请联系我:likui0913@gmail.com Compacation HBase 在读写的过程中,难免会产生无效的数据以及过小的文件,比如:MemStore 在未达到指定大小 ...

  3. Mysql 定位执行效率低的sql 语句

    一.通过MySQL慢查询日志定位执行效率低的SQL语句. MySQL通过慢查询日志定位那些执行效率较低的SQL 语句,用--log-slow-queries[=file_name]选项启动时,mysq ...

  4. Mysql-外键foreign key

    1.定义:如果一张表中有一个字段指向另一张表的主键,就子表中将该主键字段叫做外键. 一张表中可存在多个外键 2.外键的作用 保持数据的一致性.完整性 a.对子表(外键所在的表)的作用:子表在进行写操作 ...

  5. 将博客搬至CSDN和和自己的网站

    将博客同步一份到CSDN去, CSDN博客地址:https://blog.csdn.net/klkfl ---------------- 分割线 2018-10-7 自己用typecho 搭建了一个博 ...

  6. linux使用密文生成os账户

    1.生成账户 [hufangrui@xxx ~]$ openssl passwd -1Password: Verifying - Password: $1$szzkROBZ$GYxffRLp8K5vW ...

  7. java异常处理-finally中使用return和throw语句

    java异常语句中的finally块通常用来做资源释放操作,如关闭文件.关闭网络连接.关闭数据库连接等.正常情况下finally语句中不应该使用return语句也不应该抛出异常,以下讨论仅限于java ...

  8. 反射就是获取该类的.class文件里面的方法,属性

    反射就是获取该类的.class文件里面的方法,属性

  9. 【比赛】NOIP2017 列队

    一直忘了发,现在赶快补 用权值线段树维护有人的位置,动态开点省空间 多加的人用个vector存下来就可以了 #include<bits/stdc++.h> #define ui unsig ...

  10. 洛谷 P3942 将军令 解题报告

    P3942 将军令 题目描述 又想起了四月. 如果不是省选,大家大概不会这么轻易地分道扬镳吧? 只见一个又一个昔日的队友离开了机房. 凭君莫话封侯事,一将功成万骨枯. 梦里,小\(F\)成了一个给将军 ...