敌兵布阵 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. 31. 干货系列从零用Rust编写正反向代理,HTTP限流的实现(limit_req)

    wmproxy wmproxy已用Rust实现http/https代理, socks5代理, 反向代理, 静态文件服务器,四层TCP/UDP转发,七层负载均衡,内网穿透,后续将实现websocket代 ...

  2. NCTF2022-Crypto WP

    superecc 题目 from Crypto.Util.number import * from secrets import INF, flag assert flag[:5] == b'nctf ...

  3. 深入了解UUID:生成、应用与优势

    一.引言 在当今数字化时代,唯一标识一个对象的能力变得越来越重要.UUID(Universally Unique Identifier,通用唯一标识符)应运而生,作为一种保证全球唯一性的标识方法,广泛 ...

  4. NodeJS连接mysql,报错ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client

    我是mysql8.0以上的版本,在用NodeJS连接服务器中mysql数据库时开始报错 这表示服务器启动起来,但是数据库中密码协议出错,我从网上查到的结果告诉我,是mysql8.0支持了一个新的密码协 ...

  5. PanguHA,一款Windows双机热备工具

    1.简介 PanguHA是Windows平台的双机热备集群系统,是提供系统高可用性的解决方案,一般由两个节点构成,分为活动节点及备用节点(两者之间可以相互切换),软件界面如下 PanguHA下载地址 ...

  6. MybatisPlus属性自动填充

    阿里巴巴开发规范,对于每一张表都因该有id(主键),createTime(创建时间),updateTime(修改时间)这三个字段 主键ID我们可以使用自增,或者雪花算法 创建时间修改时间我们可以使用数 ...

  7. CentOS7部署后优化配置

    1.安装必要的组件.升级 yum -y install wget vim cd /etc/yum.repos.d/ rm -rf /etc/yum.repos.d/*.repo wget http:/ ...

  8. STM32CubeMX教程6 TIM 通用定时器 - 生成PWM波

    1.准备材料 开发板(STM32F407G-DISC1) ST-LINK/V2驱动 STM32CubeMX软件(Version 6.10.0) keil µVision5 IDE(MDK-Arm) 逻 ...

  9. 七天.NET 8操作SQLite入门到实战 - 第七天BootstrapBlazor UI组件库引入(1)

    前言 由于第七天Blazor前端页面编写和接口对接的内容比较的多,所以这一章节将会分为三篇文章来进行讲解,大家可以认为分为早.中.晚来进行阶段性学习,从而提高学习效率. 七天.NET 8 操作 SQL ...

  10. 标注工具合集(点云&图片)

    有什么问题欢迎留言交流,发现好用的会持续更新-- 图片类 1. labelimg:https://github.com/tzutalin/labelImg --- 只能拉框 2. labelme:ht ...