敌兵布阵 HDU - 1166

多组输入,注意清除tr数组

维护一个前缀数组,耗时有点大

#include <cstdio>
#include <cstring>
using namespace std;
const int maxn = 5e4 + 5;
int t, n;
int sum[maxn], num[maxn];
char str[10];
int main() {
// freopen("in.txt", "r", stdin);
scanf("%d", &t);
for (int kase = 1; kase <= t; kase++) {
memset(sum, 0, sizeof(sum));
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
scanf("%d", num + i);
sum[i] = sum[i - 1] + num[i];
}
int a, b;
printf("Case %d:\n", kase);
while (scanf("%s", str) && str[0] != 'E') {
scanf("%d%d", &a, &b);
if (str[0] == 'Q') {
int res = sum[b] - sum[a - 1];
printf("%d\n", res);
continue;
}
else if (str[0] == 'A') {
for (int i = a; i <= n; i++) {
sum[i] += b;
}
}
else if (str[0] == 'S') {
for (int i = a; i <= n; i++) {
sum[i] -= b;
}
}
}
}
return 0;
}

树状数组模板

#include<bits/stdc++.h>
using namespace std;
#define sc(n) scanf("%c",&n)
#define sd(n) scanf("%d",&n)
#define pd(n) printf("%d\n", (n))
#define sdd(n,m) scanf("%d %d",&n,&m)
#define sddd(n,m,z) scanf("%d %d %d",&n,&m,&z)
#define pdd(n,m) printf("%d %d\n",n, m)
#define ms(a,b) memset(a,b,sizeof(a))
#define mod(x) ((x)%MOD)
#define lowbit(x) (x & (-x)) typedef long long ll;
typedef pair<int, int> PII;
typedef vector<int> VI;
typedef vector<string> VS;
const int MOD = 10000007;
const int inf = 0x3f3f3f3f;
const int maxn = 5e5 + 100;
int n, tr[maxn], t; void update(int x, int val) {
while (x <= n) {
tr[x] += val;
x += lowbit(x);
}
} int getsum(int x) {
int res = 0;
while (x) {
res += tr[x];
x -= lowbit(x);
}
return res;
} int main() {
//freopen("in.txt", "r", stdin);
//ios::sync_with_stdio(false); cin.tie(0); cout.tie(0);
int N; cin >> N;
for (int K = 1; K <= N; ++K) {
ms(tr, 0);
cin >> n;
for (int i = 1; i <= n; ++i)cin >> t, update(i, t);
printf("Case %d:\n", K);
string s; int a, b;
while (cin >> s && s != "End") {
cin >> a >> b;
if (s == "Query")cout << getsum(b) - getsum(a - 1) << endl;
if (s == "Add") update(a, b);
if (s == "Sub") update(a, -b);
}
} return 0;
}

线段树

#include <cstdio>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std; typedef long long LL;
typedef pair<int, int> pii; const int maxn = 2e5 + 5;
const int INF = 0x3f3f3f3f; int sum[maxn * 4], A[maxn]; void PushUp(int rt) {
sum[rt] = sum[rt * 2] + sum[rt * 2 + 1];
}
void Build(int l, int r, int rt) {
if (l == r) {
sum[rt] = A[l];
return;
}
int m = (l + r) / 2;
Build(l, m, rt * 2);
Build(m + 1, r, rt * 2 + 1);
PushUp(rt);
}
void Update(int L, int c, int l, int r, int rt) {
if (r == l) {
sum[rt] += c;
return;
}
int m = (l + r) / 2;
if (L <= m) Update(L, c, l, m, rt * 2);
else Update(L, c, m + 1, r, rt * 2 + 1);
PushUp(rt);
}
int Query(int L, int R, int l, int r, int rt) {
if (L <= l && r <= R) {
return sum[rt];
}
int m = (l + r) / 2;
int ans = 0;
if (L <= m) ans += Query(L, R, l, m, rt * 2);
if (R > m) ans += Query(L, R, m + 1, r, rt * 2 + 1);
return ans;
} int main() {
// freopen("in.txt", "r", stdin);
char c;
int T;
int n, m, a, b;
char str[10];
scanf("%d", &T);
for (int kase = 1; kase <= T; kase++) {
printf("Case %d:\n", kase);
scanf("%d", &n);
memset(sum, 0, sizeof(sum));
memset(A, 0, sizeof(A));
for (int i = 1; i <= n; i++) scanf("%d", A + i);
Build(1, n, 1);
while (scanf("%s", str) && str[0] != 'E') {
scanf("%d%d", &a, &b);
if (str[0] == 'Q') {
printf("%d\n", Query(a, b, 1, n, 1));
}
else if (str[0] == 'A') {
Update(a, b, 1, n, 1);
}
else if (str[0] == 'S') {
Update(a, -b, 1, n, 1);
}
}
}
return 0;
}

HDU--1166--单点更新的更多相关文章

  1. HDU 1166 单点更新,区间求和

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  2. hdu 1166 (单点更新+区间求和+裸题)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...

  3. hdu 1754 单点更新

    题意:很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感.不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师 ...

  4. HDU 2795 单点更新,区间优先查找(想法)

    Billboard Time Limit: 20000/8000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  5. HDU 1754 单点更新,求区间最大值

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  6. hdu 1754(单点更新 ,区间最大值)

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  7. 敌兵布阵 HDU - 1166 - 单点修改,区间查询:树状数组/线段树

    C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...

  8. 线段树(单点更新and成段更新)

    线段树需要的空间. 区间为1-->n 假设是一棵完全二叉树,且树高为i. 完全二叉树性质:第i层最多有2^(i-1)个结点. 那么 2^(i-1) = n;     i = log2(n)  + ...

  9. HDU 1166 敌兵布阵(线段树单点更新,板子题)

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submi ...

  10. HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)

    HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...

随机推荐

  1. 工厂模式(Factory Method)

    模式定义 定义一个用于创建对象的接口,让子类决定实例化哪一个类.Factory Method使得一个类的实例化延迟(目的:解耦)到子类. 要点总结 Factory Method模式用于隔离类对象的使用 ...

  2. 图文剖析 big.js 四则运算源码

    big.js,一个小型.快速的用于任意精度的十进制算术的JavaScript 库. big.js 用于解决平常项目中进行算术运算时精度丢失引起的结果不准确的问题.和 big.js 类似的两个库 big ...

  3. 生成模型的两大代表:VAE和GAN

    生成模型 给定数据集,希望生成模型产生与训练集同分布的新样本.对于训练数据服从\(p_{data}(x)\):对于产生样本服从\(p_{model}(x)\).希望学到一个模型\(p_{model}( ...

  4. [scrapy]一个简单的scrapy爬虫demo

    一个简单的scrapy爬虫demo 爬取豆瓣top250的电影名称+电影口号 使用到持久化流程: 爬虫文件爬取到数据后,需要将数据封装到items对象中. 使用yield关键字将items对象提交给p ...

  5. [ABC246C] Coupon

    Problem Statement There are $N$ items in a shop. For each $i = 1, 2, \ldots, N$, the price of the $i ...

  6. [ABC265F] Manhattan Cafe

    Problem Statement In an $N$-dimensional space, the Manhattan distance $d(x,y)$ between two points $x ...

  7. style绑定及随机颜色

    一个小案例 颜色变换 style单机事件的绑定

  8. 使用SPEL自定义表达式

    自定义表达式 Spring提供了一个可以自定义表达式的接口 package com.qbb.qmall.item; import org.junit.Test; import org.springfr ...

  9. 华企盾DSC导致金蝶导入Excel导入不了的问题

    需要把Excel的OLE控制关掉,并且金蝶的进程和Excel的进程高级设置要么都启用重定向,要么都不启用重定向

  10. svn、git服务器配置进程方式网关不生效常见处理方法

    过华企盾DSC防泄密系统配置svn或者git服务器的时候,网关不生效如何解决? 1.先在cmd中运行一下命令netstat -ano|findstr "8080" 找到svn.gi ...