学习线段树~~~~~~~~~~~~要好好理解

此题是单点更新的线段树,考虑基本的询问,更新。

#include <iostream>
#include <algorithm>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include <vector>
#include <set>
#include <queue>
#include <stack>
#include <climits>//形如INT_MAX一类的
#define MAX 50005
#define INF 0x7FFFFFFF
#define REP(i,s,t) for(int i=(s);i<=(t);++i)
#define ll long long
#define mem(a,b) memset(a,b,sizeof(a))
#define mp(a,b) make_pair(a,b)
# define eps 1e-5
//#pragma comment(linker, "/STACK:36777216") ///传说中的外挂
using namespace std;
struct node
{
int left,right,mid,value,cover;
} edge[4*MAX]; void build(int l,int r,int num)
//l,r为当前节点的左右端点,num为当前节点在数组中的下标
{
edge[num].left = l;
edge[num].right = r;
edge[num].value = 0;
edge[num].mid = (l+r) >> 1;
if(l != r) // 如果不是叶子节点
{
build(l,edge[num].mid,num * 2); //左子树
build(edge[num].mid + 1,r,num*2+1); //右子树
}
}
void update(int num,int mid,int v)
//单点更新 mid为更新点,v为更新值
{
if(edge[num].left == mid && edge[num].right == mid)
{
edge[num].value += v;
return ;
}
if(edge[num].mid >= mid)
update(2*num,mid,v);
else
update(2*num+1,mid,v);
edge[num].value = edge[num*2].value + edge[num*2+1].value; // 注意是‘=’不是‘+=’,更新值
} int query(int l,int r,int num)
{
if(l <= edge[num].left && r >= edge[num].right)
{
return edge[num].value;
}
if(r <= edge[num].mid)
return query(l,r,num*2);
else if(l >= edge[num].mid + 1)
return query(l,r,num *2+1);
else
{
return query(l,edge[num].mid,num*2) + query(edge[num].mid+1,r,num*2+1);
}
}
/*
void insert(int l,int r ,int num)
//l,r为插入段的左右端点,num为当前结点的下标
{
if(l <= edge[num].left && r >= edge[num].right)
//插入段完全大于当前段
{
edge[num].cover = 1;
return ;
}
if(r <= edge[num].mid) //插入段被当前段的左子树包含
insert(l,r,2 * num);
else if(l >= edge[num].mid + 1)//插入段被当前段的右子树包含
insert(l,r,2*num+1);
else
{
insert(l,edge[num].mid, 2* num);
insert(edge[num].mid+1,r,2*num+1);
}
}
*/
int main()
{
int t,i,j;
int casee = 1;
char str[10];
cin >> t;
while(t--)
{
printf("Case %d:\n",casee++);
int n,a;
cin >> n;
build(1,n,1);
for(i=1; i<=n; i++)
{
scanf("%d",&a);
update(1,i,a);
}
while(scanf("%s",str))
{
if(str[0] == 'E')
break;
if(str[0] == 'Q')
{
scanf("%d%d",&i,&j);
printf("%d\n",query(i,j,1));
}
if(str[0] == 'A')
{
scanf("%d%d",&i,&j);
update(1,i,j);
}
if(str[0] == 'S')
{
scanf("%d%d",&i,&j);
update(1,i,-j);
}
}
}
return 0;
}

hdu 1166 敌兵布阵(线段树基础题)的更多相关文章

  1. hdu 1166敌兵布阵(线段树入门题)

    >>点击进入原题测试<< 思路:这两天在学线段树,这个题直接手敲一下线段树就行了,都没有用上懒人标记.入门题 cin,cout会超时,记得加std::ios::sync_wit ...

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

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

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

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

  4. HDU 1166 敌兵布阵(线段树单点更新,板子题)

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

  5. HDU 1166 敌兵布阵(线段树单点更新)

    敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...

  6. HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  7. HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>

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

  8. hdu 1166 敌兵布阵 (线段树、单点更新)

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

  9. hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题

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

  10. HDU 1166 敌兵布阵 线段树

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

随机推荐

  1. 条形码(JBarcode)

    一世尘梦 少小离家老大回,妖娆尘世,程序唧唧:问君能有几多愁,恰是满屏BUG无处修. 商品条形码(JBarcode) 之前没有使用过这个,现在使用JBarcode生成商品条形码,工作之前的准备工作: ...

  2. Installshield建立IE快捷方式的方法

    原文:Installshield建立IE快捷方式的方法 实现方法:在project assistant里或者install design里随便建一个快捷方式,然后去install design里修改刚 ...

  3. APACHE启动失败是SYSTEM对apache目录没权限导致

    表现如下: Apache: 1.The Apache service named reported the following error:>>> (OS 5)拒绝访问. : htt ...

  4. OpenStreetMap架构

    OpenStreetMap框架简介 1.OSM平台开发 OpenStreetMap(缩写OSM)地图是一个合作项目,我们的目标是创建一个免费的内容,让所有的人都可以编辑的世界地图. OSM在地图上由一 ...

  5. SQL点滴34—SQL中的大小写

    原文:SQL点滴34-SQL中的大小写 默认情况下,SQL Server不区分大小写,如果数据表TEST的TNAME列中有数据“abcd”和“Abcd”, 如果使用查询语句:select * from ...

  6. Perl基础(1)chop与chomp的区别

    chop是去掉字符串的最后一个字符 chomp是去掉"$/"指定的结尾符号 测试程序一: [perl] #!/bin/perl $tmp = "sincere" ...

  7. Grub启动配置文件

    和许多其他linux发行版一样,Fedora使用Grub作为32位和64位X86系统的启动加载器(bootloader).grub的配置文件主要是/boot/grub/grub.conf,而/boot ...

  8. leetcode第15题--3Sum

    Problem: Given an array S of n integers, are there elements a, b, c in S such that a + b + c = 0? Fi ...

  9. leetcode[158] Read N Characters Given Read4 II - Call multiple times

    想了好一会才看懂题目意思,应该是: 这里指的可以调用更多次,是指对一个文件多次操作,也就是对于一个case进行多次的readn操作.上一题是只进行一次reandn,所以每次返回的是文件的长度或者是n, ...

  10. [置顶] Android开发之Thread类分析

    在我们Linux系统中创建线程函数为:pthread_create(),在Android中我们为线程封装了一个类Thread,实际调用的还是pthread_create() 当我们想创建线程的时候,只 ...