Description

C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了。A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况。由于采取了某种先进的监测手段,所以每个工兵营地的人数C国都掌握的一清二楚,每个工兵营地的人数都有可能发生变动,可能增加或减少若干人手,但这些都逃不过C国的监视。 
中央情报局要研究敌人究竟演习什么战术,所以Tidy要随时向Derek汇报某一段连续的工兵营地一共有多少人,例如Derek问:“Tidy,马上汇报第3个营地到第10个营地共有多少人!”Tidy就要马上开始计算这一段的总人数并汇报。但敌兵营地的人数经常变动,而Derek每次询问的段都不一样,所以Tidy不得不每次都一个一个营地的去数,很快就精疲力尽了,Derek对Tidy的计算速度越来越不满:"你个死肥仔,算得这么慢,我炒你鱿鱼!”Tidy想:“你自己来算算看,这可真是一项累人的工作!我恨不得你炒我鱿鱼呢!”无奈之下,Tidy只好打电话向计算机专家Windbreaker求救,Windbreaker说:“死肥仔,叫你平时做多点acm题和看多点算法书,现在尝到苦果了吧!”Tidy说:"我知错了。。。"但Windbreaker已经挂掉电话了。Tidy很苦恼,这么算他真的会崩溃的,聪明的读者,你能写个程序帮他完成这项工作吗?不过如果你的程序效率不够高的话,Tidy还是会受到Derek的责骂的. 
 

Input

第一行一个整数T,表示有T组数据。 
每组数据第一行一个正整数N(N<=50000),表示敌人有N个工兵营地,接下来有N个正整数,第i个正整数ai代表第i个工兵营地里开始时有ai个人(1<=ai<=50)。 
接下来每行有一条命令,命令有4种形式: 
(1) Add i j,i和j为正整数,表示第i个营地增加j个人(j不超过30) 
(2)Sub i j ,i和j为正整数,表示第i个营地减少j个人(j不超过30); 
(3)Query i j ,i和j为正整数,i<=j,表示询问第i到第j个营地的总人数; 
(4)End 表示结束,这条命令在每组数据最后出现; 
每组数据最多有40000条命令 
 

Output

对第i组数据,首先输出“Case i:”和回车, 
对于每个Query询问,输出一个整数并回车,表示询问的段中的总人数,这个数保持在int以内。 
 

Sample Input

  1. 1
  2. 10
  3. 1 2 3 4 5 6 7 8 9 10
  4. Query 1 3
  5. Add 3 6
  6. Query 2 7
  7. Sub 10 2
  8. Add 6 3
  9. Query 3 10
  10. End
 

Sample Output

  1. Case 1:
  2. 6
  3. 33
  4. 59

分析:这是典型的更新线段上的一个点然后查询线段上的区间的和,算是线段树的模版应用题目了,因为只有点更新,所有再找点的时候所有的节点都进行了更新,也就没必要再去做下压或者上升之类的更新了

******************************************************************************
  1. #include<stdio.h>
  2. #include<math.h>
  3. #include<string.h>
  4.  
  5. #define maxn 50005
  6.  
  7. struct node
  8. {
  9.     int L, R, sum;//左右子树,sum记录区间和
  10.     int Mid(){return (L+R)/2;}
  11. }tree[maxn*4];//为了保险起见一般定义是四倍
  12. int val[maxn];//保存每个阵地原来的人数
  13.  
  14. void Build(int root, int L, int R)//建树
  15. {
  16.     tree[root].= L, tree[root].= R;
  17.  
  18.     if(== R)
  19.     {
  20.         tree[root].sum = val[L];
  21.         return ;
  22.     }
  23.  
  24.     Build(root<<1, L, tree[root].Mid());//<<1 运算符相当于乘上 2,因为是数往左移一位
  25.     Build(root<<1|1, tree[root].Mid()+1, R);//|1, 因为左移后最后一位是0, 所以与1进行|相当于+1
  26.  
  27.     tree[root].sum = tree[root<<1].sum+tree[root<<1|1].sum;//区间和等于左右区间的和
  28. }
  29. //k表示需要更新的点,e表示需要更新的值
  30. void Insert(int root, int k, int e)
  31. {
  32.     tree[root].sum += e;
  33.     if(tree[root].== tree[root].R)
  34.         return ;
  35.  
  36.     if(<= tree[root].Mid())
  37.         Insert(root<<1, k, e);
  38.     else
  39.         Insert(root<<1|1, k, e);
  40. }
  41. //查询区间LR的和
  42. int Query(int root, int L, int R)
  43. {
  44.     if(tree[root].== L && tree[root].== R)
  45.         return tree[root].sum;
  46.  
  47.     //如果在左子树区间
  48.     if(<= tree[root].Mid())
  49.         return Query(root<<1, L, R);
  50.     else if(> tree[root].Mid())//如果在右子树区间
  51.         return Query(root<<1|1, L, R);
  52.     else
  53.     {//在左右子树
  54.         int Lsum = Query(root<<1, L, tree[root].Mid());
  55.         int Rsum = Query(root<<1|1, tree[root].Mid()+1, R);
  56.  
  57.         return Lsum + Rsum;
  58.     }
  59. }
  60.  
  61. int main()
  62. {
  63.     int T, t=1;
  64.  
  65.     scanf("%d", &T);
  66.  
  67.     while(T--)
  68.     {
  69.         int i, N, x, y;
  70.  
  71.         scanf("%d", &N);
  72.  
  73.         for(i=1; i<=N; i++)
  74.             scanf("%d", &val[i]);
  75.         Build(1, 1, N);
  76.  
  77.         char s[10];
  78.  
  79.         printf("Case %d:\n", t++);
  80.  
  81.         while(scanf("%s", s), s[0] != 'E')
  82.         {
  83.             scanf("%d%d", &x, &y);
  84.  
  85.             if(s[0] == 'A')
  86.                 Insert(1, x, y);
  87.             else if(s[0] == 'S')
  88.                 Insert(1, x, -y);
  89.             else
  90.             {
  91.                 int ans = Query(1, x, y);
  92.                 printf("%d\n", ans);
  93.             }
  94.         }
  95.     }
  96.  
  97.     return 0;
  98. }

A - 敌兵布阵 - hdu 1166的更多相关文章

  1. 敌兵布阵 HDU 1166 线段树

    敌兵布阵 HDU 1166 线段树 题意 这个题是用中文来描写的,很简单,没什么弯. 解题思路 这个题肯定就是用线段树来做了,不过当时想了一下可不可用差分来做,因为不熟练就还是用了线段树来做,几乎就是 ...

  2. A - 敌兵布阵 HDU - 1166 线段树(多点修改当单点修改)

    线段树板子题练手用 #include<cstdio> using namespace std; ; int a[maxn],n; struct Node{ int l,r; long lo ...

  3. 敌兵布阵 HDU - 1166 (树状数组模板题,线段树模板题)

    思路:就是树状数组的模板题,利用的就是单点更新和区间求和是树状数组的强项时间复杂度为m*log(n) 没想到自己以前把这道题当线段树的单点更新刷了. 树状数组: #include<iostrea ...

  4. 敌兵布阵 HDU - 1166 板子题

    #include <cstdio> #include <cstring> #include <iostream> #include <algorithm> ...

  5. A - 敌兵布阵(HDU 1166)

    A - 敌兵布阵 HDU - 1166 思路:线段树单点修改+区间查询. #include<cstdio> #include<cstring> #include<iost ...

  6. HDU 1166 敌兵布阵 (树状数组)

    题目链接 : http://acm.hdu.edu.cn/showproblem.php?pid=1166 敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    ...

  7. HDU 1166 敌兵布阵(分块)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  8. hdu acm 1166 敌兵布阵 (线段树)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  9. HDU 1166 敌兵布阵

    B - 敌兵布阵 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Submit Sta ...

随机推荐

  1. ProgressBar 基本介绍

    简介 ProgressBar 继承自View,用于在界面上显示一个进度指示的界面. 1.ProgressBar有两个进度,一个是android:progress,另一个是android:seconda ...

  2. 关于git的一些常用命令

    1.git init 把目录变成Git可以管理的仓库 2.git add 把文件添加到仓库 3.git commit -m "" 把文件提交到仓库,-m后面是提交说明 4.git ...

  3. (转)JS的parent对象

    ---http://blog.sina.com.cn/s/blog_a15aa5690101a5yz.html top:该变更永远指分割窗口最高层次的浏览器窗口.如果计划从分割窗口的最高层次开始执行命 ...

  4. 用DOM实现文章采集-HtmlAgilityPack实现html解析

    Html Agility Pack 是CodePlex 上的一个开源项目.它提供了标准的DOM API 和XPath 支持! 下载地址:http://htmlagilitypack.codeplex. ...

  5. Swift - 27 - 使用元组让函数返回多个值

    //: Playground - noun: a place where people can play import UIKit // 定义一个数组 var userScores:[Int]? = ...

  6. cas sso单点登录系列6_cas单点登录防止登出退出后刷新后退ticket失效报500错

    转(http://blog.csdn.net/ae6623/article/details/9494601) 问题: 我登录了client2,又登录了client3,现在我把client2退出了,在c ...

  7. linux 命令及进程控制

    main.c  main.o/main.obj  main/main.exe          编译                连接 程序运行;      两步: gcc/g++  -c  mai ...

  8. 【USACO 3.1.1】最短网络

    [描述]      农民约翰被选为他们镇的镇长!他其中一个竞选承诺就是在镇上建立起互联网,并连接到所有的场.当然,他需要你的帮助.     约翰已经给他的农场安排了一条高速的网络线路,他想把这条线路共 ...

  9. Chrome扩展与用户隐私

    转载自https://www.imququ.com/post/chrome-extensions-and-user-privacy.html   Google Chrome浏览器应该早就是大家的默认了 ...

  10. java使用json抛出org.apache.commons.lang.exception.NestableRuntimeException解决方案

    出现这个问题,说明缺少jar包,将下面的jar引入即可 commons-beanutils-1.8.3 commons-lang-2.6 (注:导入最新的 3.1 版本会继续报如下错误) common ...