HDU--1166--单点更新
敌兵布阵 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--单点更新的更多相关文章
- HDU 1166 单点更新,区间求和
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- hdu 1166 (单点更新+区间求和+裸题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submissi ...
- hdu 1754 单点更新
题意:很多学校流行一种比较的习惯.老师们很喜欢询问,从某某到某某当中,分数最高的是多少.这让很多学生很反感.不管你喜不喜欢,现在需要你做的是,就是按照老师的要求,写一个程序,模拟老师的询问.当然,老师 ...
- HDU 2795 单点更新,区间优先查找(想法)
Billboard Time Limit: 20000/8000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- HDU 1754 单点更新,求区间最大值
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- hdu 1754(单点更新 ,区间最大值)
I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total S ...
- 敌兵布阵 HDU - 1166 - 单点修改,区间查询:树状数组/线段树
C国的死对头A国这段时间正在进行军事演习,所以C国间谍头子Derek和他手下Tidy又开始忙乎了.A国在海岸线沿直线布置了N个工兵营地,Derek和Tidy的任务就是要监视这些工兵营地的活动情况.由于 ...
- 线段树(单点更新and成段更新)
线段树需要的空间. 区间为1-->n 假设是一棵完全二叉树,且树高为i. 完全二叉树性质:第i层最多有2^(i-1)个结点. 那么 2^(i-1) = n; i = log2(n) + ...
- HDU 1166 敌兵布阵(线段树单点更新,板子题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- HDU.1166 敌兵布阵 (线段树 单点更新 区间查询)
HDU.1166 敌兵布阵 (线段树 单点更新 区间查询) 题意分析 加深理解,重写一遍 代码总览 #include <bits/stdc++.h> #define nmax 100000 ...
随机推荐
- Jenkins从Ubuntu迁移至AlmaLinux问题及相关解决记录
相关背景 之前在Ubuntu平台上搭建了Jenkins(在Ubuntu机器上使用war包安装Jenkins),现在由于一些需求,需要将系统迁移到AlmaLinux平台.由于AlmaLinux属于Cen ...
- .net 下优秀的DI框架推荐,看看你用过几个?
在.NET生态系统中,有许多出色的依赖注入(DI)框架可供选择.每个框架都有其独特的特点和优点,可以根据项目需求和偏好进行选择.下面详细介绍一些.NET中优秀的DI框架,它们的优点以及适用场景. 1. ...
- NVIDIA RTX4090,你能用它做什么?
都说男生是世界上最简单的动物,为什么呢?举个例子,你要给女朋友送礼,你可以选择包.口红.护肤品.化妆品等,而包的品牌和样式.口红的色号等足以让你挑得眼花缭乱.而男生不一样,如果女生选择给男生送礼,我相 ...
- SpringBoot-Validation优雅实现参数校验
1.是什么? 它简化了 Java Bean Validation 的集成.Java Bean Validation 通过 JSR 380,也称为 Bean Validation 2.0,是一种标准化的 ...
- 【类型转换】使用c#实现简易的类型转换(Emit,Expression,反射)
引言 哈喽.大家好,好久不见,最近遇到了一个场景,就是在FrameWork的asp.net mvc中,有个系统里面使用的是EntityFramework的框架,在这个框架里,提供了一个SqlQuery ...
- 笔记本安装linux
下载 桌面版 Ubuntu 镜像 服务器版 Ubuntu 镜像 使用 Balena Etcher 制作系统安装盘 (1)官方网站下载: 点我下载 (2)下载完毕软件之后,打开软件,选择我们下载好的系统 ...
- vulntarget-d-wp
vulntarget-d 配置信息 系统 ip kali 192.168.130.5 ubuntu 18 ip1: 192.168.130.8 ip2: 10.0.10.1 win7 10.0.10. ...
- Centos7 Zabbix3.2安装(yum)
http://repo.zabbix.com/zabbix/3.2/rhel/7/x86_64/ #官网下载地址(只包含zabbix的应用包) ftp://47.104.78.123/zabbix/ ...
- 从源码分析 MySQL 身份验证插件的实现细节
最近在分析ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)这个报错的常见原因. 在 ...
- Terraform 的开源替代:OpenTofu 宣布 GA!
OpenTofu 社区于1月10日宣布 OpenTofu 项目 GA,这是 OpenTofu 的首个稳定版本(https://github.com/opentofu/opentofu/releases ...