区间查询(树状数组之差点问线问题)

1110: 区间查询

时间限制: 2 Sec
内存限制: 32 MB
提交: 162
解决: 62
提交 状态

题目描述

食堂有N个打饭窗口,现在正到了午饭时间,每个窗口都排了很多的学生,而且每个窗口排队的人数在不断的变化。
现在问你第i个窗口到第j个窗口一共有多少人在排队?

输入

输入的第一行是一个整数T,表示有T组测试数据。
每组输入的第一行是一个正整数N(N<=30000),表示食堂有N个窗口。
接下来一行输入N个正整数,第i个正整数ai表示第i个窗口最开始有ai个人排队。(1<=ai<=50)
接下来每行有一条命令,命令有四种形式:
(1)Add i j,i和j为正整数,表示第i个窗口增加j个人(j不超过30);
(2)Sub i j,i和j为正整数,表示第i个窗口减少j个人(j不超过30);
(3)Query i j,i和j为正整数,i<=j,表示询问第i到第j个窗口的总人数;
(4)End 表示结束,这条命令在每组数据最后出现;
每组数据最多有40000条命令。

输出

对于每组输入,首先输出样例号,占一行。
然后对于每个Query询问,输出一个整数,占一行,表示询问的段中的总人数,这个数保持在int以内。

样例输入

1101 2 3 4 5 6 7 8 9 10Query 1 3Add 3 6Query 2 7Sub 10 2Add 6 3Query 3 10End

样例输出

Case 1:63359

提示

#include
#include
#include
using namespace std;
int n,c1[30010];
int lowbit(int n)
{
    return n&(-n);
}
int add(int i,int data)
{
    while(i<=n)
    {
        c1[i]+=data;
        i+=lowbit(i);
    }
}
long long sum(int i)
{
    long long sum1=0;
    while(i>0)
    {
        sum1+=c1[i];
        i-=lowbit(i);
    }
    return sum1;
}
int main()
{
    int times,i,b,d,a,f=1;
    char c[20];
    cin>>times;
    while(times--)
    {
        memset(c1,0,sizeof(c1));
        cin>>n;
        cout<<"Case "<>a;
            add(i,a);
        }
        while(cin>>c)
        {
            if(strcmp(c,"End")==0)
            {
                break;
            }
            else if(strcmp(c,"Add")==0)
            {
                    cin>>b>>d;
                    add(b,d);
            }
            else if(strcmp(c,"Sub")==0)
            {
                cin>>b>>d;
                add(b,-d);
            }
            else
            {
                cin>>b>>d;
                cout<

你可能感兴趣的:(树状数组)