敌兵布阵 HDU - 1166 (树状数组模板题,线段树模板题)
思路:就是树状数组的模板题,利用的就是单点更新和区间求和是树状数组的强项时间复杂度为m*log(n)
没想到自己以前把这道题当线段树的单点更新刷了。
树状数组:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn = 5e4 + ;
int tree[maxn], n;
void add(int k, int num)
{
while (k <= n)
{
tree[k] += num;
k += k&-k;
}
}
int sum(int k)
{
int sum = ;
while (k)
{
sum += tree[k];
k -= k&-k;
}
return sum;
}
int main()
{
int t, x, y, k=;
scanf("%d", &t);
while (t--)
{
memset(tree, , sizeof(tree));
scanf("%d", &n);
for (int i = ; i <= n; ++i)
{
scanf("%d", &x); add(i, x);
}
char num[];
printf("Case %d:\n", ++k);
while (scanf("%s", num), strcmp(num, "End") != )
{
scanf("%d%d", &x, &y);
if (strcmp(num,"Add")==){ add(x, y); }
else if (strcmp(num,"Sub")==){ add(x, -y); }
else{ printf("%d\n", sum(y) - sum(x-)); }
}
}
}
线段树
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
#define MID(a,b) (a+((b-a)>>1))
#define MAXN int(1e4)*5+5
struct node
{
int l, r;
int sum;
int mid(){ return MID(l, r); }
}; int num[MAXN], n; struct Tree
{
node tree[MAXN << ];
void build(int L, int R, int pos)
{
tree[pos].l = L; tree[pos].r = R; //表示区间
tree[pos].sum = ;
if (L == R){tree[pos].sum = num[R]; return; }//到了子叶
int mid = tree[pos].mid();
//二分
build(L, mid, pos<<);
build(mid + , R, pos << | );
tree[pos].sum = tree[pos << ].sum + tree[pos << | ].sum;
}
//valu 表示加的值, ind 表示第几个军营。(在区域中的位置)
void updata(int ind, int pos, int valu)
{
if (tree[pos].l == tree[pos].r)
{
tree[pos].sum += valu; return; //叶节点+valu
}
int mid = tree[pos].mid();
//二分查找单点位置?
if (ind <= mid) updata(ind, pos << , valu);
else updata(ind, pos << | , valu);
tree[pos].sum = tree[pos << ].sum + tree[pos << | ].sum;
//递归,覆盖上一层的sum
}
//查询
int query(int L, int R, int pos)//从根节点查到符合的区间节点
{
if (L <= tree[pos].l&&tree[pos].r <= R) return tree[pos].sum;
int mid = tree[pos].mid();
int sum1 = , sum2 = ;
if (L <= mid) sum1 = query(L, R, pos << );
if (R > mid) sum2 = query(L, R, pos << | );
return sum1 + sum2;
}
};
Tree tree;
int main()
{
int x, y;
int t, n,t_case=;
scanf("%d", &t);
while (t--)
{
char ch[];
scanf("%d", &n);
printf("Case %d:\n", ++t_case);
for (int i = ; i <= n; i++)
scanf("%d", &num[i]);
tree.build(, n, );
while (scanf("%s", ch) != EOF)
{
if (strcmp(ch, "End") == ) break;
else if (strcmp(ch,"Add")==)
{
scanf("%d%d", &x, &y);
tree.updata(x, , y);
}
else if (strcmp(ch, "Sub") == )
{
scanf("%d%d", &x, &y);
tree.updata(x, , -y);
}
else if (strcmp(ch, "Query") == )
{
scanf("%d%d", &x, &y);
printf("%d\n", tree.query(x, y, ));
}
}
}
return ;
}
敌兵布阵 HDU - 1166 (树状数组模板题,线段树模板题)的更多相关文章
- 敌兵布阵 HDU 1166 线段树
敌兵布阵 HDU 1166 线段树 题意 这个题是用中文来描写的,很简单,没什么弯. 解题思路 这个题肯定就是用线段树来做了,不过当时想了一下可不可用差分来做,因为不熟练就还是用了线段树来做,几乎就是 ...
- HDU 1166敌兵布阵+NOJv2 1025: Hkhv love spent money(线段树单点更新区间查询)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 【BZOJ3110】【整体二分+树状数组区间修改/线段树】K大数查询
Description 有N个位置,M个操作.操作有两种,每次操作如果是1 a b c的形式表示在第a个位置到第b个位置,每个位置加入一个数c 如果是2 a b c形式,表示询问从第a个位置到第b个位 ...
- [Usaco2014 Open Gold ]Cow Optics (树状数组+扫描线/函数式线段树)
这道题一上手就知道怎么做了= = 直接求出原光路和从目标点出发的光路,求这些光路的交点就行了 然后用树状数组+扫描线或函数式线段树就能过了= = 大量的离散+模拟+二分什么的特别恶心,考试的时候是想到 ...
- bzoj4785:[ZJOI2017]树状数组:二维线段树
分析: "如果你对树状数组比较熟悉,不难发现可怜求的是后缀和" 设数列为\(A\),那么可怜求的就是\(A_{l-1}\)到\(A_{r-1}\)的和(即\(l-1\)的后缀减\( ...
- A - 敌兵布阵 HDU - 1166 线段树(多点修改当单点修改)
线段树板子题练手用 #include<cstdio> using namespace std; ; int a[maxn],n; struct Node{ int l,r; long lo ...
- A - 敌兵布阵 - hdu 1166
Description C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些 ...
- BZOJ 3110([Zjoi2013]K大数查询-区间第k大[段修改,在线]-树状数组套函数式线段树)
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MB Submit: 418 Solved: 235 [ Submit][ ...
- BZOJ 4785 [Zjoi2017]树状数组 | 二维线段树
题目链接 BZOJ 4785 题解 这道题真是令人头秃 = = 可以看出题面中的九条可怜把求前缀和写成了求后缀和,然后他求的区间和却仍然是sum[r] ^ sum[l - 1],实际上求的是闭区间[l ...
随机推荐
- .net导出excle无需任何插件,直接通过一个tablehtml实现
项目背景: 项目需要导出样式复杂的excl表格,主要是一些样式布局比较复杂 技术分析: 目前比较通用的实现方式有 1.借助微软的excle插件 2.通过NPOI插件实现 3.直接导出一个html(ta ...
- JS通过百度地图API获取当前定位信息
$(function(){ var latlon=null; //ajax获取用户所在经纬度 $.ajax({ url:"http://api.map.baidu.com/location/ ...
- HDFS的副本存放策略(全)
HDFS的副本存放策略 HDFS作为Hadoop中的一个分布式文件系统,而且是专门为它的MapReduce设计,所以HDFS除了必须满足自己作为分布式文件系统的高可靠性外,还必须为MapReduc ...
- 第一个SpringBoot程序
第一个SpringBoot程序 例子来自慕课网廖师兄的免费课程 2小时学会SpringBoot Spring Boot进阶之Web进阶 使用IDEA新建工程,选择Spring Initializr,勾 ...
- Minitab系列 前言
Matlab 在有些时候太过去强大,强大到几乎所有的数学问题都可以解决. 在这里,Matlab就像数学版的Vim,对于一般的使用者还是不想编程,想要更加的直接直观的数学处理工具,这里向大家介绍mini ...
- Django Rest Framework之权限
基本代码结构 url.py: from django.conf.urls import url, include from app import views urlpatterns = [ url(r ...
- Thymeleaf学习记录(1)--启动模板及建立Demo
Thymeleaf是什么? Thymeleaf是适用于Web和独立环境的现代服务器端Java模板引擎.相比于JSP,Thymeleaf更简洁,渲染性能更好,维护性更好,它可以XML/XHTML/HTM ...
- loadrunner 运行脚本-Run-time Settings->General->Additional attributes设置
运行脚本-Run-time Settings->General->Additional attributes设置 by:授客 QQ:1033553122 作用说明 为Vuser脚本提供额外 ...
- 《Inside C#》笔记(十三) 多线程 上
通过将一个任务划分成多个任务分别在独立的线程执行可以更有效地利用处理器资源并节省时间.但如果不合理地使用多线程,反而会带来种种问题并拖慢运行速度. 一 线程基础 a)线程与多任务 一个线程就是一个处理 ...
- (网页)js最新手机号码、电话号码正则表达式
正则表达式(regular expression)是一个描述字符模式的对象.使用JavaScript正则表达式可以进行强大的模式匹配和文本检索与替换功能. 手机号码正则表达式验证. function ...