HDU1166-敌兵布阵(线段树)
题目链接: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-敌兵布阵(线段树)的更多相关文章
- HDU-1166敌兵布阵(线段树)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...
- hdu1166 敌兵布阵(线段树 求区间和 更新点)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- hdu1166 敌兵布阵 线段树(区间更新)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- HDU1166 敌兵布阵(线段树)
C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...
- 【生活没有希望】hdu1166敌兵布阵 线段树
线段树水题刷刷,生活没有希望 最近看到代码跟树状数组差不多短的非递归线段树,常数也很小——zkw线段树 于是拿道水题练练手 短到让人身无可恋 ;pos;pos/=) a[pos]+=x;} ,ans= ...
- HDU1166 敌兵布阵 线段树详解
题解: 更新是线段树的单点更新,简单一点. 有50000个阵营,40000查询,用普通数组肯定超时.区间求和和区间查询问题用线段树最好不过了. 先说说什么是线段树. 区间[1,10]用树的方法存起来, ...
- HDU1166 敌兵布阵 —— 线段树单点修改
题目链接:https://vjudge.net/problem/HDU-1166 C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布 ...
- HDU1166 敌兵布阵 [线段树模板]
题意:在序列中修改单点和查询区间和 #include<iostream> #include<cstdio> #include<cstring> #define ls ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
随机推荐
- BestCoder Round #11 题解集合
1001.Alice and Bob 签到题*1,只要x * 2 == n && y * 2 == m就满足条件. var m, n, x, y : int64; begin whil ...
- ANGULAR 开发用户选择器指令
在开发表单时,我们需要使用经常需要使用到用户选择器,用户的数据一般使用如下方式存储: 用户1,用户2,用户3 我们可以使用angular指令实现选择器. <!DOCTYPE html> ...
- C#基础学习文章导航
第一部分:入个门 C#入门篇-1:HelloWorld的类 C#入门篇-2:什么是变量 C#入门篇-3:数据类型及转换 C#入门篇-4:使用运算符 第二部分:流程控制语句 C#入门篇5-1:流程控制语 ...
- spring的bean管理
1.所有的类都可以交给Spring管理 2.如何把一个类交给bean管理? (1)配置applicationContext.xml (2)在xml中写入bean节点配置要交给bean管理的类 3.程序 ...
- hadoop集群配置实例
1)ssh配置 http://allthingshadoop.com/2010/04/20/hadoop-cluster-setup-ssh-key-authentication/ 2) 修改打开文件 ...
- bzoj 2282: [Sdoi2011]消防
#include<cstdio> #include<cstring> #include<iostream> #define N 600000 using names ...
- HDU 1754 单点更新,求区间最大值
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- POJ 1436 Horizontally Visible Segments
题意: 有一些平行于y轴的线段 ,两条线段称为互相可见当且仅当存在一条水平线段连接这两条 与其他线段没交点. 最后问有多少组 3条线段,他们两两是可见的. 思路: 线段树,找出两两可见的那些组合, ...
- 用PDB库调试Python程序
Python自带的pdb库,发现用pdb来调试程序还是很方便的,当然了,什么远程调试,多线程之类,pdb是搞不定的. 用pdb调试有多种方式可选: 1. 命令行启动目标程序,加上-m参数,这样调用my ...
- 简易模仿手机拨号盘浮在ListView之上并且展开,折叠效果
2013-12-24 16:56:45 有时候可以看到很多手机会将Call log list和Dailer放在同一个页面中,同时Dialer是可以折叠.打开的,自己做了一个Demo,能实现这种效果,简 ...