A Simple Problem with Integers

Posted wzl19981116

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了A Simple Problem with Integers相关的知识,希望对你有一定的参考价值。

来源poj3468

You have N integers, A1, A2, ... , AN. You need to deal with two kinds of operations. One type of operation is to add some given number to each number in a given interval. The other is to ask for the sum of numbers in a given interval.

Input

The first line contains two numbers N and Q. 1 ≤ N,Q ≤ 100000.
The second line contains N numbers, the initial values of A1, A2, ... , AN. -1000000000 ≤ Ai ≤ 1000000000.
Each of the next Q lines represents an operation.
"C a b c" means adding c to each of Aa, Aa+1, ... , Ab. -10000 ≤ c ≤ 10000.
"Q a b" means querying the sum of Aa, Aa+1, ... , Ab.

Output

You need to answer all Q commands in order. One answer in a line.

Sample Input

10 5
1 2 3 4 5 6 7 8 9 10
Q 4 4
Q 1 10
Q 2 4
C 3 6 3
Q 2 4

区间修改的线段树

#include<iostream>
#include<stdio.h>
#include<stdlib.h>
#include <iomanip>
#include<cmath>
#include<float.h> 
#include<string.h>
#include<algorithm>
#include<vector>
#include<queue>
#define sf scanf
#define pf printf
#define scf(x) scanf("%d",&x)
#define scff(x,y) scanf("%d%d",&x,&y)
#define scfff(x,y,z) scanf("%d%d%d",&x,&y,&z)
#define prf(x) printf("%d
",x) 
#define mm(x,b) memset((x),(b),sizeof(x))
#define rep(i,a,n) for (int i=a;i<n;i++)
#define per(i,a,n) for (int i=a;i>=n;i--)
typedef long long ll;
const ll mod=1e9+7;
const double eps=1e-8;
const int inf=0x3f3f3f3f;
using namespace std;
const double pi=acos(-1.0);
const int N=1e6+10;
struct TREE
{
    ll l,r;
    ll sum;
}tr[N];
ll a[N];
ll add[N];
void built_tree(ll x,ll y,ll i)
{
    tr[i].l =x;tr[i].r =y;
    if(x==y)
    tr[i].sum =a[x];
    else
    {
        ll mid=(x+y)>>1;
        built_tree(x,mid,i<<1);
        built_tree(mid+1,y,i<<1|1);
        tr[i].sum=tr[i<<1].sum+tr[i<<1|1].sum; 
    }
}
void pushdown(int i)//下放惰性标记 
{
    ll lc=i<<1,rc=i<<1|1;
    tr[lc].sum +=(tr[lc].r -tr[lc].l +1)*add[i];
    tr[rc].sum +=(tr[rc].r -tr[rc].l +1 )*add[i];
    add[lc]+=add[i];
    add[rc]+=add[i];
    add[i]=0;
}
void update_tree(ll x,ll y,ll k,int i)
{
    ll lc=i<<1;
    ll rc=i<<1|1;
    if(tr[i].l>y||tr[i].r<x) return; //如果不属于,则返回
    if(x <= tr[i].l &&tr[i].r <=y)
    {
        tr[i].sum+=(tr[i].r -tr[i].l +1)*k;//加至此处不继续往下加 
        add[i]+=k;//存惰性标记 
    }else
    {
        if(add[i])
            pushdown(i);
        update_tree(x,y,k,lc);
        update_tree(x,y,k,rc);
        tr[i].sum =tr[lc].sum+tr[rc].sum; 
    } //查找 
}

ll query(ll x,ll y,int i)
{
    ll lc=i<<1,rc=i<<1|1;
    if(x <= tr[i].l && tr[i].r <= y) return tr[i].sum;
    if(x > tr[i].r|| y < tr[i].l) return 0;
    if(add[i])
        pushdown(i);
    return query(x,y,lc)+query(x,y,rc);
}

int main()
{
    int n,q;
    scff(n,q);
    rep(i,1,n+1)
    sf("%lld",&a[i]);
    built_tree(1,n,1);
    while(q--)
    {
        char c;
        cin>>c;ll x,y,z;
        if(c==‘Q‘)
        {
            sf("%lld%lld",&x,&y);
            pf("%lld
",query(x,y,1));
        }else
        {
            sf("%lld%lld%lld",&x,&y,&z);
            update_tree(x,y,z,1);
        }
    }
    return 0;
}










以上是关于A Simple Problem with Integers的主要内容,如果未能解决你的问题,请参考以下文章

POJ3468A Simple Problem with Integers

线段树专题 POJ3468 A Simple Problem with Integers

A Simple Problem with Integers

A Simple Problem with Integers

POJ 3468 A Simple Problem with Integers

POJ3468 A Simple Problem with Integers