题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166

 #include<bits/stdc++.h>
using namespace std;
class Node
{
private:
int val;
Node *left, *right; public:
Node();
void set_val(int v);
void set_left(Node* t);
void set_right(Node* t);
int get_val();
Node* get_left();
Node* get_right();
}; Node::Node()
{
left = NULL;
right = NULL;
val = ;
} void Node::set_val(int v)
{
val = v;
} void Node::set_left(Node *t)
{
left = t;
} void Node::set_right(Node *t)
{
right = t;
} int Node::get_val()
{
return val;
} Node* Node::get_left()
{
return left;
} Node* Node::get_right()
{
return right;
} void build(int l, int r, Node* cur, int *a)
{
if(l == r)
{
cur->set_val(a[l]);
return;
}
int mid = (l + r) >> ; cur->set_left(new Node);
build(l, mid, cur->get_left(), a); cur->set_right(new Node);
build(mid+, r, cur->get_right(), a); cur->set_val(cur->get_left()->get_val() + cur->get_right()->get_val());
} void change(int i, int j, int curl, int curr, Node* cur)
{
if(curl == curr)
{
cur->set_val(cur->get_val() + j);
return;
} int mid = (curl + curr)>>;
if(i <= mid)
change(i, j, curl, mid, cur->get_left());
else
change(i, j, mid+, curr, cur->get_right()); cur->set_val(cur->get_left()->get_val() + cur->get_right()->get_val());
} int Search(int l, int r, int curl, int curr, Node* cur)
{
if(l <= curl && r >= curr)
return cur->get_val(); int mid = (curl + curr)>>;
if(l > mid)
return Search(l, r, mid+, curr, cur->get_right()); if(r <= mid)
return Search(l, r, curl, mid, cur->get_left()); return Search(l, r, curl, mid, cur->get_left()) + Search(l, r, mid+, curr, cur->get_right());
}
int main()
{
int T;
scanf("%d", &T);
char command[],c[][]={"End","Query","Add","Sub"};
for(int cas = ; cas <= T; cas++)
{
int n;
scanf("%d", &n);
int *a = new int[n+];
for(int i = ; i <= n; i++)
scanf("%d", &a[i]);
Node *root = new Node;
build(, n, root, a);
printf("Case %d:\n", cas);
int i, j;
for(;;)
{
scanf("%s", command);
if(!strcmp(command,c[]))
break; else
{
scanf("%d %d",&i, &j);
if(!strcmp(command,c[]))
printf("%d\n",Search(i, j ,, n, root));
else if(!strcmp(command,c[]))
change(i, j, , n, root);
else if(!strcmp(command,c[]))
change(i, -j, , n, root);
}
}
delete root;
delete a;
}
return ;
}

HDU1166-敌兵布阵(线段树)的更多相关文章

  1. HDU-1166敌兵布阵(线段树)

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

  2. hdu1166 敌兵布阵(线段树 求区间和 更新点)

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

  3. hdu1166 敌兵布阵 线段树(区间更新)

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

  4. HDU1166 敌兵布阵(线段树)

    C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...

  5. 【生活没有希望】hdu1166敌兵布阵 线段树

    线段树水题刷刷,生活没有希望 最近看到代码跟树状数组差不多短的非递归线段树,常数也很小——zkw线段树 于是拿道水题练练手 短到让人身无可恋 ;pos;pos/=) a[pos]+=x;} ,ans= ...

  6. HDU1166 敌兵布阵 线段树详解

    题解: 更新是线段树的单点更新,简单一点. 有50000个阵营,40000查询,用普通数组肯定超时.区间求和和区间查询问题用线段树最好不过了. 先说说什么是线段树. 区间[1,10]用树的方法存起来, ...

  7. HDU1166 敌兵布阵 —— 线段树单点修改

    题目链接:https://vjudge.net/problem/HDU-1166 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布 ...

  8. HDU1166 敌兵布阵 [线段树模板]

    题意:在序列中修改单点和查询区间和 #include<iostream> #include<cstdio> #include<cstring> #define ls ...

  9. HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)

    HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...

  10. hdu 1166 敌兵布阵 线段树 点更新

    // hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...

随机推荐

  1. Android实现Activity页面跳转切换动画特效

    了解Android程序设计的人应该知道,在Android 2.0之后有了overridePendingTransition(),其中里面两个参数,一个是前一个activity的退出,另一个activi ...

  2. 项目中Enum枚举的使用

    在.NET中,枚举一般有两种常见用法,一是表示唯一的元素序列,比如表示订单状态(未提交,待处理,处理中...).另外一种是表示多种组合的状态,比如表示权限,因为可同时有多个不同权限. 基本用法 这里拿 ...

  3. 键盘控制select选项上下

    $('#k').live('keydown',function(event){ if (event.keyCode==38){ /*$(this).addClass("active" ...

  4. Expression<Func<T, bool>>

    public static Expression<Func<T, bool>> True<T>() { return f => true; } public ...

  5. UVa 11361 - Investigating Div-Sum Property

    http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...

  6. strstr strchr strrchr

    通过函数的定义来区分: 1.strstr: 返回子串出现的第一次位置 char *strstr(const char *haystack, const char *needle) 可见,strstr函 ...

  7. Ibatis.Net 数据库操作(四)

    一.查询select 还记得第一篇示例中的是如何读出数据库里的3条数据吗? 就是调用了一个QueryForList方法,从方法名就知道,查询返回列表. 1.QueryForList 返回List< ...

  8. ubuntu 14.04 安装 foxit pdf阅读器

    1.官网下载 http://www.foxitsoftware.cn/downloads/ 2.安装 tar -zxvf FoxitReader1.01.0925_Server_x64_enu_Set ...

  9. [ASP.NET] 使用Loading遮罩防止使用者重複點擊

    From: http://www.dotblogs.com.tw/joysdw12/archive/2012/12/13/85629.aspx 前言 在網頁執行中可能會因為資料量大或其他原因影響使用者 ...

  10. Rhel6-heartbeat配置文档

    系统环境: rhel6 x86_64 iptables and selinux disabled 主机: 192.168.122.119 server19.example.com 192.168.12 ...