Luogu P3374 [템플릿] 트리 형 배열 1 (단일 포인트 업데이트 + 단일 포인트 평가)

이야기:

여기에 사진 설명 삽입

암호:

#include<bits/stdc++.h>
using namespace std;
const int N=5*1e5+100;
int n,m,tree[N];
int lowbit(int i)
{
    
    
	return i&(-i);
}
void updata(int i,int k)
{
    
    
	while(i<=n)
	{
    
    
		tree[i]+=k;
		i+=lowbit(i);
	}
}
int quiry(int i)
{
    
    
	int res=0;
	while(i>0)
	{
    
    
		res+=tree[i];
		i-=lowbit(i);
	}
	return res;
}
int main()
{
    
    
	cin>>n>>m;
	for(int i=1;i<=n;i++){
    
    
		int k;
		cin>>k;
		updata(i,k);
	}
	while(m--)
	{
    
    
		int t,x;
		cin>>t>>x;
		if(t==1){
    
    
			int k;
			cin>>k;
			updata(x,k);
			/*for(int i=1;i<=n;i++) cout<<tree[i]<<" ";
			cout<<endl;*/
		}
		else{
    
    
			int y;
			cin>>y;
			cout<<quiry(y)-quiry(x-1)<<endl;
		}
	}
	return 0;
}
 

요약하자면 :

이러한 유형의 질문은 접두사의 합과 유사합니다. 모든 업데이트 또는 평가는 x에서 시작하여 lowbit (x)를 줄여 수정해야합니다.

추천

출처blog.csdn.net/Lzhzl211/article/details/114802800