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

相关文章

使用Java填充Word模板的操作指南

《使用Java填充Word模板的操作指南》本文介绍了Java填充Word模板的实现方法,包括文本、列表和复选框的填充,首先通过Word域功能设置模板变量,然后使用poi-tl、aspose-words... 目录前言一、设置word模板普通字段列表字段复选框二、代码1. 引入POM2. 模板放入项目3.代码

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

Python进行word模板内容替换的实现示例

《Python进行word模板内容替换的实现示例》本文介绍了使用Python自动化处理Word模板文档的常用方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友... 目录技术背景与需求场景核心工具库介绍1.获取你的word模板内容2.正常文本内容的替换3.表格内容的

PHP应用中处理限流和API节流的最佳实践

《PHP应用中处理限流和API节流的最佳实践》限流和API节流对于确保Web应用程序的可靠性、安全性和可扩展性至关重要,本文将详细介绍PHP应用中处理限流和API节流的最佳实践,下面就来和小编一起学习... 目录限流的重要性在 php 中实施限流的最佳实践使用集中式存储进行状态管理(如 Redis)采用滑动

深入浅出Spring中的@Autowired自动注入的工作原理及实践应用

《深入浅出Spring中的@Autowired自动注入的工作原理及实践应用》在Spring框架的学习旅程中,@Autowired无疑是一个高频出现却又让初学者头疼的注解,它看似简单,却蕴含着Sprin... 目录深入浅出Spring中的@Autowired:自动注入的奥秘什么是依赖注入?@Autowired

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

PostgreSQL简介及实战应用

《PostgreSQL简介及实战应用》PostgreSQL是一种功能强大的开源关系型数据库管理系统,以其稳定性、高性能、扩展性和复杂查询能力在众多项目中得到广泛应用,本文将从基础概念讲起,逐步深入到高... 目录前言1. PostgreSQL基础1.1 PostgreSQL简介1.2 基础语法1.3 数据库