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 ...
随机推荐
- Tcc学习笔记(三) 使用举例
TCC的使用以使用第三方库为例子,例子包括:OpenGL , GMP以及SDL等. 1.TCC使用GLUT 去OpenGL下载http://www.opengl.org/resources/libra ...
- Unity协程截图,WWWForm、WWW配合上传
先说一下原理.. 截图有两种方法,第一种: Application.CaptureScreenshot(url); 这个API可以截全屏并保存到指定路径 这里我们不采用此方法 下面的代码采用第二种方法 ...
- git 常用操作
查看某文件的某些行的变化历史: $ git log --pretty=short -u -L 2003,2005:Executor.cpp http://stackoverflow.com/quest ...
- css元素居中方法
几种居中方式,分情况使用: 1.已知父盒子宽度,子盒子宽度: div{ transform: translate(-50%,-50%); //margin-left: - 自身宽度一半: positi ...
- 关闭Win10自带的 Windows Defender
1.按下Win+R,输入gpedit.msc 2.进入组策略,选择计算机配置>管理模板>Windows 组件>Windows Defender 3.双击"关闭 Window ...
- Android学习---SQLite数据库的增删改查和事务(transaction)调用
上一篇文章中介绍了手工拼写sql语句进行数据库的CRUD操作,本文将介绍调用sqlite内置的方法实现CRUD操作,其实质也是通过拼写sql语句. 首先,创建一个新的android项目: 其次,查看代 ...
- GDI+图形图像处理技术中Pen和Brush的简单使用和简单图形的绘制(C#)
1.Graphics Graphics对象是GDI+绘图表面,因此在Windows窗体应用程序中要使用GDI+创建绘图,必须要先创建Graphics.在给窗体注册一个Paint事件后,Graphics ...
- sk_buff封装和解封装网络数据包的过程详解(转载)
http://dog250.blog.51cto.com/2466061/1612791 可以说sk_buff结构体是Linux网络协议栈的核心中的核心,几乎所有的操作都是围绕sk_buff这个结构体 ...
- 分析‖为什么越来越多厂商开始发力VR一体机?
2015年下半年,国内VR头显市场的主旋律还是PC头显和手机盒子.到了2016年上半年,一体机逐渐上位,成为发布会上的主角. 近期IDEALENS启视在北京召开发布会,发布会的主角K2和K2Pro正是 ...
- 数据导出Excel
package com.jy.pjbj.web.action.util; import java.io.File;import java.util.List; import javax.xml.rpc ...