hdu acm 1166 敌兵布阵 (线段树)
敌兵布阵
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 37903 Accepted Submission(s): 15985
10
1 2 3 4 5 6 7 8 9 10
Query 1 3
Add 3 6
Query 2 7
Sub 10 2
Add 6 3
Query 3 10
End
6
33
59
/*
hdu 1166 敌兵布阵
线段树 基本操作
by zhh
*/
#include <iostream>
#include <stdio.h>
#include <cstring>
#include <algorithm>
#include <stdlib.h> using namespace std;
int a[]; struct line
{
int left;
int right;
int sum;
}p[];
void build(int l,int r,int s)//建立线段树,并在域sum中赋初值
{
p[s].left=l;
p[s].right=r;
if(l==r)
{
p[s].sum=a[l];
return ;
}
build(l,(l+r)/,s*);
build((l+r)/+,r,s*+);
p[s].sum=p[s*].sum+p[s*+].sum;
}
void add(int i,int j,int s)//增加数之后刷新线段树
{
if(p[s].left<=i&&p[s].right>=i)
{
p[s].sum+=j;
if(p[s].left==p[s].right)
return;
add(i,j,s*);
add(i,j,s*+); }
}
/*void add(int i,int j,int s)
{
if(p[s].left==i&&p[s].right==i)
{
p[s].sum=j;
return;
}
int mid=(p[s].left+p[s].right)/2;
if(i<=mid) add(i,j,s*2);
else add(i,j,s*2+1);
p[s].sum=p[s*2].sum+p[s*2+1].sum; }*/
int finds(int i,int j,int s)//查找所给线段上的sum和
{
if(p[s].left>j)
return ;
if(p[s].right<i)
return ;
if(p[s].left>=i&&p[s].right<=j)
return p[s].sum;
return finds(i,j,s*)+finds(i,j,s*+);
}
/*int finds(int i,int j,int s)
{
if(p[s].left==i&&p[s].right==j)
return p[s].sum;
int mid=(p[s].left+p[s].right)/2;
if(mid>=j) return finds(i,j,s*2);
if(mid<i) return finds(i,j,s*2+1);
return finds(i,mid,s*2)+finds(mid+1,j,s*2+1);
}*/
int main()
{
int T;
cin>>T;
for(int t_n=;t_n<=T;t_n++)
{
printf("Case %d:\n",t_n);
int n,sum=;
cin>>n;
a[]=;
for(int i=;i<=n;i++)
{
cin>>a[i];
}
build(,n,);
char order[];
int i,j;
scanf("%s",order);
while(order[]!='E')
{
scanf("%d %d",&i,&j);
if(order[]=='A')
{
// a[i]+=j;
// j=a[i];
add(i,j,);
} if(order[]=='S')
{
// a[i]-=j;
// j=a[i];
add(i,-j,);//减可以被认为加上负的 }
if(order[]=='Q')
printf("%d\n",finds(i,j,));
scanf("%s",order);
}
}
return ;
}
hdu acm 1166 敌兵布阵 (线段树)的更多相关文章
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
- hdu 1166 敌兵布阵 线段树 点更新
// hdu 1166 敌兵布阵 线段树 点更新 // // 这道题裸的线段树的点更新,直接写就能够了 // // 一直以来想要进线段树的坑,结果一直没有跳进去,今天算是跳进去吧, // 尽管十分简单 ...
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- HDU 1754 线段树 单点跟新 HDU 1166 敌兵布阵 线段树 区间求和
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...
- HDU 1166 敌兵布阵 <线段树 单点修改 区间查询>
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 1166 敌兵布阵 (线段树、单点更新)
敌兵布阵Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submiss ...
- hdu 1166 敌兵布阵 线段树区间修改、查询、单点修改 板子题
题目链接:敌兵布阵 题目: C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视 ...
- HDU 1166 敌兵布阵(线段树单点更新)
敌兵布阵 单点更新和区间更新还是有一些区别的,应该注意! [题目链接]敌兵布阵 [题目类型]线段树单点更新 &题意: 第一行一个整数T,表示有T组数据. 每组数据第一行一个正整数N(N< ...
- HDU 1166 敌兵布阵 线段树
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- AFNetworking图片缓存问题
AFNetworking网络库已经提供了很好的图片缓存机制,效率是比较高的,但是我发现没有直接提供清除缓存的功能,可项目通常都需要添加 清除功能的功能,因此,在这里我以UIImageView+AFNe ...
- ios UILabel在storyBoard或xib中如何在每行文字不显示完就换行
大家知道怎么用代码让label中的文字换行,只需要 label.numberOfLines = 0; label.text = @"这是第一行啦啦啦啦,\n这是第二行啦啦,\n这是第三行&q ...
- mysql中的游标使用案例
DELIMITER $$ DROP PROCEDURE IF EXISTS `curTest`$$ CREATE PROCEDURE curTest(IN _myId INT) BEGIN DECLA ...
- mysql 计算日期差
有两个途径可获得 1.利用TO_DAYS函数 select to_days(now()) - to_days('20140831') 2.利用DATEDIFF函数 select dat ...
- .NET技术大系概览 (迄今为止最全的.NET技术栈)
从2002年的.NET 1.0开始,1.1,2.x,3.x,4.x,每个新版本的.NET都会增加新的技术,生态圈也在不断壮大. AD: 前言 .Net推出13年了,Visual Studio 2015 ...
- 推荐大家使用的CSS书写规范、顺序
写了这么久的CSS,但大部分前端er都没有按照良好的CSS书写规范来写CSS代码,这样会影响代码的阅读体验,这里总结一个CSS书写规范.CSS书写顺序供大家参考,这些是参考了国外一些文章以及我的个人经 ...
- mysql中的where和having子句的区别
mysql中的where和having子句的区别 having的用法 having字句可以让我们筛选成组后的各种数据,where字句在聚合前先筛选记录,也就是说作用在group by和having字句 ...
- 海量数据相似度计算之simhash短文本查找
在前一篇文章 <海量数据相似度计算之simhash和海明距离> 介绍了simhash的原理,大家应该感觉到了算法的魅力.但是随着业务的增长 simhash的数据也会暴增,如果一天100w, ...
- C#类和接口、虚方法和抽象方法及值类型和引用类型的区别
1.C#类和接口的区别接口是负责功能的定义,项目中通过接口来规范类,操作类以及抽象类的概念!而类是负责功能的具体实现!在类中也有抽象类的定义,抽象类与接口的区别在于:抽象类是一个不完全的类,类里面有抽 ...
- c#一个泛型控制Textbox 和label 控件 泛型方法。
class ControlHelper { public static void ShowOnTxtLbl<T>(T control, string mess) where T : Sys ...