HDU 1166 敌兵布阵【线段树应用类型一 点更新,区间求和)】【模板】

2024-02-19 14:18

本文主要是介绍HDU 1166 敌兵布阵【线段树应用类型一 点更新,区间求和)】【模板】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

题目连接及大佬连接

///修改点,更新区间求和 模板
/*算是第一篇敲这个模板吧,注释标准*/#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=50000+5;//线段树需要维护的信息
int sum[maxn*4];
#define lson i*2, l, m
#define rson i*2+1, m+1, r
/*i节点收集子节点的统计结果*/
void PushUP(int i)
{sum[i]=sum[i*2]+sum[i*2+1];
}///递归建立线段树,i代表当前节点的编号,l,r为当前节点所代表的的区间
void build (int i, int l,int r)
{if(l==r)///当前节点为叶子节点{scanf("%d",&sum[i]);///直接构建叶节点return ;}int m=(l+r)/2;build(lson);///构建左子树build(rson);///构建右子树PushUP(i);///收集子节点的更新结果,也就是自下向上更新
}
///*在当前的区间[l,r]内 查询区间[ql,qr]区间的目标值,且能执行这个区间的前提是:
///[ql,qr]的交集非空其实本函数返回的结果就是他们交集的结果
int query(int ql,int qr,int i,int l,int r)
{if(ql<=l&&r<=qr) return sum[i];///询问的区间在当前区间,返回当前维护好的值int m=(l+r)/2;int res=0;if(ql<=m) res+=query(ql,qr,lson);if(m<qr) res+=query(ql,qr,rson);return res;
}///update()这个函数在不同题
///本题是单点更新,所以在区间[l,r]内使得第id数的值 +val,如果是区间更新,可以update的参数需将id变为ql,和qrvoid update(int id,int val,int i,int l,int r)
{if(l==r){sum[i]+=val;return ;}int m=(l+r)/2;if(id<=m) update(id,val,lson);else update(id,val,rson);PushUP(i);///时刻记住 维护i节点统计信息的正确性
}int main()
{int T;scanf("%d",&T);for(int case1=1;case1<=T;case1++){printf("Case %d:\n",case1);int n;scanf("%d",&n);build(1,1,n);char str[20];int u,v;while(scanf("%s",str)==1&&str[0]!='E'){scanf("%d%d",&u,&v);if(str[0]=='Q') printf("%d\n",query(u,v,1,1,n));else if(str[0]=='A') update(u,v,1,1,n);else update(u,-v,1,1,n);}}return 0;
}

 

这篇关于HDU 1166 敌兵布阵【线段树应用类型一 点更新,区间求和)】【模板】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/724931

相关文章

中文分词jieba库的使用与实景应用(一)

知识星球:https://articles.zsxq.com/id_fxvgc803qmr2.html 目录 一.定义: 精确模式(默认模式): 全模式: 搜索引擎模式: paddle 模式(基于深度学习的分词模式): 二 自定义词典 三.文本解析   调整词出现的频率 四. 关键词提取 A. 基于TF-IDF算法的关键词提取 B. 基于TextRank算法的关键词提取

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

poj3468(线段树成段更新模板题)

题意:包括两个操作:1、将[a.b]上的数字加上v;2、查询区间[a,b]上的和 下面的介绍是下解题思路: 首先介绍  lazy-tag思想:用一个变量记录每一个线段树节点的变化值,当这部分线段的一致性被破坏我们就将这个变化值传递给子区间,大大增加了线段树的效率。 比如现在需要对[a,b]区间值进行加c操作,那么就从根节点[1,n]开始调用update函数进行操作,如果刚好执行到一个子节点,

hdu1394(线段树点更新的应用)

题意:求一个序列经过一定的操作得到的序列的最小逆序数 这题会用到逆序数的一个性质,在0到n-1这些数字组成的乱序排列,将第一个数字A移到最后一位,得到的逆序数为res-a+(n-a-1) 知道上面的知识点后,可以用暴力来解 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#in

hdu1689(线段树成段更新)

两种操作:1、set区间[a,b]上数字为v;2、查询[ 1 , n ]上的sum 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdl

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

zoj3820(树的直径的应用)

题意:在一颗树上找两个点,使得所有点到选择与其更近的一个点的距离的最大值最小。 思路:如果是选择一个点的话,那么点就是直径的中点。现在考虑两个点的情况,先求树的直径,再把直径最中间的边去掉,再求剩下的两个子树中直径的中点。 代码如下: #include <stdio.h>#include <string.h>#include <algorithm>#include <map>#

usaco 1.3 Mixing Milk (结构体排序 qsort) and hdu 2020(sort)

到了这题学会了结构体排序 于是回去修改了 1.2 milking cows 的算法~ 结构体排序核心: 1.结构体定义 struct Milk{int price;int milks;}milk[5000]; 2.自定义的比较函数,若返回值为正,qsort 函数判定a>b ;为负,a<b;为0,a==b; int milkcmp(const void *va,c

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]