[HDU - 1166] 敌兵布阵 线段树/树状数组板子题

题目链接:敌兵布阵
题意

中文题意,我就不多说了

题解

线段树点修改的板子/树状数组板子

代码

线段树

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<bitset>
#include<cassert>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<deque>
#include<iomanip>
#include<list>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
using namespace std;
//extern "C"{void *__dso_handle=0;}
typedef long long ll;
typedef long double ld;
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define pii pair<int,int>

const double PI=acos(-1.0);
const double eps=1e-6;
const ll mod=1e9+7;
const int inf=0x3f3f3f3f;
const int maxn=1e5+10;
const int maxm=100+10;
#define ios ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);

int a[maxn],tree[maxn];
void build(int p,int l,int r)
{
	if(l==r) { tree[p]=a[l]; return ;}
	int mid=l+(r-l)/2;
	build(p*2, l, mid);
	build(p*2+1,mid+1,r);
	tree[p]=tree[p*2]+tree[p*2+1];
}
void add(int p,int l,int r,int num,int v)
{
	int mid=l+(r-l)/2;
	if(l==r) { tree[p]+=v; return; }
	if(num<=mid) add(p*2,l, mid, num, v); else add(p*2+1, mid+1, r, num, v);
	tree[p]=tree[p*2]+tree[p*2+1];
}
int query(int p,int l,int r,int ql,int qr)
{
	int mid=l+(r-l)/2,ans=0;
	if(ql<=l && qr>=r) return tree[p];
	if(ql<=mid) ans+=query(p*2, l, mid, ql, qr);
	if(mid<qr) ans+=query(p*2+1, mid+1, r, ql, qr);
	return ans;
}

int main()
{
	int t;
	scanf("%d",&t);
	for(int cas=1;cas<=t;cas++)
	{
		int n;
		scanf("%d",&n);
		for(int i=1;i<=n;i++) scanf("%d",&a[i]);
		printf("Case %d:\n",cas);
		build(1, 1, n);
		int q;
		string s;
		while(cin >> s)
		{
			if(s=="Add")
			{
				int num,v;
				scanf("%d%d",&num,&v);
				add(1, 1, n, num, v);
			}
			else if(s=="Sub")
			{
				int num,v;
				scanf("%d%d",&num,&v);
				v=-v;
				add(1, 1, n, num, v);
			}
			else if(s=="End")
			{
				break ;
			}
			else
			{
				int l,r;
				scanf("%d%d",&l,&r);
				cout << query(1, 1, n,l,r) << endl;	
			}
		}
	}
}

树状数组

#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#include<bitset>
#include<cassert>
#include<cctype>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<deque>
#include<iomanip>
#include<list>
#include<map>
#include<queue>
#include<set>
#include<stack>
#include<vector>
using namespace std;
//extern "C"{void *__dso_handle=0;}
typedef long long ll;
typedef long double ld;
#define fi first
#define se second
#define pb push_back
#define mp make_pair
#define pii pair<int,int>
#define lowbit(x) x&-x

const double PI=acos(-1.0);
const double eps=1e-6;
const ll mod=1e9+7;
const int inf=0x3f3f3f3f;
const int maxn=1e5+10;
const int maxm=100+10;
#define ios ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);

int a[maxn],c[maxn];
int n;
int sum(int x)
{
	int ans=0;
	while(x>0)
	{
		ans+=c[x],x-=lowbit(x);
	}
	return ans;
}
void add(int x,int num)
{
	while (x<=n) {
		c[x]+=num,x+=lowbit(x);
	}
}
int main()
{
	int t;
	scanf("%d",&t);
	for(int cas=1;cas<=t;cas++)
	{
		memset(c, 0, sizeof(c));
		scanf("%d",&n);
		for(int i=1;i<=n;i++) 
		{
			scanf("%d",&a[i]);
			add(i, a[i]);
		}
		printf("Case %d:\n",cas);
		int q;
		string s;
		while(cin >> s)
		{
			if(s=="Add")
			{
				int num,v;
				scanf("%d%d",&num,&v);
				add(num, v);
			}
			else if(s=="Sub")
			{
				int num,v;
				scanf("%d%d",&num,&v);
				v=-v;
				add(num, v);
			}
			else if(s=="End") break ;
			else
			{
				int l,r;
				scanf("%d%d",&l,&r);
				printf("%d\n",sum(r)-sum(l-1));
			}
		}
	}
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值