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 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
随机推荐
- hdu 3635 Dragon Balls (带权并查集)
Dragon Balls Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- 杂记(编程style)----google code style!
1.文件名 使用小写字母和下划线组合.头文件以.h结尾,定义文件用.cc结尾.例如:my_useful_class.cc 2.类型名 使用大写字母开头,多个单词组合时每个单词的首字母大写.例如:Url ...
- Sum Root to Leaf Numbers [LeetCode]
Problem description: http://oj.leetcode.com/problems/sum-root-to-leaf-numbers/ Basic idea: To store ...
- dubug
1.设置断点 2.启动servers端的debug模式 3.运行程序,在后台遇到断点时,进入debug调试状态 ============================= 作用域 功能 快捷键 全局 ...
- Java 集合系列 14 hashCode
java 集合系列目录: Java 集合系列 01 总体框架 Java 集合系列 02 Collection架构 Java 集合系列 03 ArrayList详细介绍(源码解析)和使用示例 Java ...
- Problem 2020 组合(FOJ)
Problem 2020 组合 Accept: 714 Submit: 1724Time Limit: 1000 mSec Memory Limit : 32768 KB Problem ...
- 使用jvisualvm.exe 的Btrace插件监控应用程序
之前提到使用命令行的方式执行btrace监控,其实jdk提供更好的方式监控应用程序. 我们可以使用jvisualvm.exe加插件的方式监控,这样更加方便. 1.在jvisualvm.exe安装btr ...
- Jquery.Page.js 分页插件的使用
1.简单直接贴代码 需要引用以下样式和脚本 <link href="~/Scripts/Page/pager.css" rel="stylesheet" ...
- spring任务计划
小组 第一次小组会议结果 贾川和刘三龙负责这些任务: 1:4.11 搭配开发必要的环境,vs2010 2:4.12学习windows界面开发的基本知识 3:4.13-4.15 和小组成员讨论软件界面的 ...
- visual studio 2013连接Oracle 11g并获取数据:(一:环境搭建)
C# WinForm案例: 目标: visual studio 中点击按钮,就可获取到Oracle中数据表的内容 1.安装Visual Studio 2013 ,推荐如下网址,下载ISO镜像,一路ne ...