zoukankan      html  css  js  c++  java
  • HDU-1166 敌兵布阵 (树状数组模板题——单点更新,区间求和)

    题目链接

    AC代码:

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #include<algorithm>
    #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>
    #define mp make_pair
    #define pi acos(-1)
    #define pii pair<int, int>
    #define pll pair<long long , long long>
    #define ll long long
    #define ld long double
    #define MEMS(x) memset(x, -1, sizeof(x))
    #define MEM(x) memset(x, 0, sizeof(x))
    #define lowbit(x) x&(-x)
    const int inf = 0x3f3f3f3f;
    const int maxn = 50001;
    using namespace std;
    int T, N, c[maxn];
    char order[maxn];
    void update(int x, int y)
    {
        for(int i = x; i <= N; i += lowbit(i))
            c[i] += y;
    }
    int getsum(int x)
    {
        int ans = 0;
        while(x)
        {
            ans += c[x];
            x -= lowbit(x);
        }
        return ans;
    }
    int main()
    {
    //    freopen("input.txt", "r", stdin);
    //    freopen("output.txt", "w", stdout);
        scanf("%d", &T);
        for(int t = 1; t <= T; t++)
        {
            scanf("%d", &N);
            memset(c, 0, sizeof(c));
            for(int i = 1; i <= N; i++)
            {
                int a;
                scanf("%d", &a);
                update(i, a);
            }
            printf("Case %d:
    ", t);
            while(scanf("%s", order) != EOF)
            {
                if(!strcmp(order, "End"))
                    break;
                if(!strcmp(order, "Add"))
                {
                    int i, j;
                    scanf("%d %d", &i, &j);
                    update(i, j);
                }
                else if(!strcmp(order, "Sub"))
                {
                    int i, j;
                    scanf("%d %d", &i, &j);
                    update(i, -j);
                }
                else if(!strcmp(order, "Query"))
                {
                    int i, j;
                    scanf("%d %d", &i, &j);
                    printf("%d
    ", getsum(j) - getsum(i - 1));
                }
            }
        }
    
    }
    
    
  • 相关阅读:
    C# 实现 Snowflake算法生成唯一性Id
    kafka可视化客户端工具(Kafka Tool)的基本使用(转)
    docker 安装kafka
    Model类代码生成器
    使用docker 部署rabbitmq 镜像
    Vue 增删改查 demo
    git 提交代码到库
    Android ble蓝牙问题
    mac 配置 ssh 到git (Could not resolve hostname github.com, Failed to connect to github.com port 443 Operation timed out)
    okhttp
  • 原文地址:https://www.cnblogs.com/KeepZ/p/12315253.html
Copyright © 2011-2022 走看看