hdu1556(树状数组/线段树,区间修改,点查询)

2024-05-24 23:38

本文主要是介绍hdu1556(树状数组/线段树,区间修改,点查询),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目链接:点击打开链接

//题目大意:一段序列,给连续的一段涂色,问某个点被涂的次数#include <iostream>
#include <algorithm>
#include <fstream>
#include <sstream>
#include <iomanip>
#include <cstdio>
#include <vector>
#include <cstring>
#include <cmath>
#include <queue>
#include <stack>
#include <set>
#include <map>
#define N 100010using namespace std;int sum[N<< 2], add[N<< 2];
int a[N], n, x, y;void pushup(int k) { sum[k]= sum[k<< 1]+ sum[k<< 1| 1]; }void build(int l, int r, int k)
{if(l== r) { sum[k]= a[l]; return; }int m= (l+ r)>> 1;build(l, m, k<< 1);build(m+ 1, r, k<< 1| 1);pushup(k);
}void pushdown(int k, int ln, int rn)
{if(add[k]){add[k<< 1]+= add[k];add[k<< 1| 1]+= add[k];sum[k<< 1]+= add[k]* ln;sum[k<< 1| 1]+= add[k]* rn;add[k]= 0;}
}void update(int l, int r, int c, int ll, int rr, int k)
{if(l<= ll && r>= rr){sum[k]+= c* (rr- ll+ 1);add[k]+= c;return;}int m= (ll+ rr)>> 1;pushdown(k, m- ll+ 1, rr- m);if(l<= m) update(l, r, c, ll, m, k<< 1);if(r> m) update(l, r, c, m+ 1, rr, k<< 1| 1);pushup(k);
}int query(int l, int r, int ll, int rr, int k)
{if(l<= ll && r>= rr) return sum[k];int m= (ll+ rr)>> 1;pushdown(k, m- ll+ 1, rr- m);int ans= 0;if(l<= m) ans+= query(l, r, ll, m, k<< 1);if(r> m) ans+= query(l, r, m+ 1, rr, k<< 1| 1);return ans;
}int main()
{while(scanf("%d", &n)== 1 && n){memset(sum, 0, sizeof(sum));memset(add, 0, sizeof(add));memset(a, 0, sizeof(a));build(1, n, 1);for(int i= 0; i< n; i++){scanf("%d%d", &x, &y);update(x, y, 1, 1, n, 1);}for(int i= 1; i< n; i++) printf("%d ", query(i, i, 1, n, 1));printf("%d\n", query(n, n, 1, n, 1));}return 0;
}


这篇关于hdu1556(树状数组/线段树,区间修改,点查询)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Mybatis 传参与排序模糊查询功能实现

《Mybatis传参与排序模糊查询功能实现》:本文主要介绍Mybatis传参与排序模糊查询功能实现,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、#{ }和${ }传参的区别二、排序三、like查询四、数据库连接池五、mysql 开发企业规范一、#{ }和${ }传参的

Docker镜像修改hosts及dockerfile修改hosts文件的实现方式

《Docker镜像修改hosts及dockerfile修改hosts文件的实现方式》:本文主要介绍Docker镜像修改hosts及dockerfile修改hosts文件的实现方式,具有很好的参考价... 目录docker镜像修改hosts及dockerfile修改hosts文件准备 dockerfile 文

Python实现无痛修改第三方库源码的方法详解

《Python实现无痛修改第三方库源码的方法详解》很多时候,我们下载的第三方库是不会有需求不满足的情况,但也有极少的情况,第三方库没有兼顾到需求,本文将介绍几个修改源码的操作,大家可以根据需求进行选择... 目录需求不符合模拟示例 1. 修改源文件2. 继承修改3. 猴子补丁4. 追踪局部变量需求不符合很

浅谈mysql的sql_mode可能会限制你的查询

《浅谈mysql的sql_mode可能会限制你的查询》本文主要介绍了浅谈mysql的sql_mode可能会限制你的查询,这个问题主要说明的是,我们写的sql查询语句违背了聚合函数groupby的规则... 目录场景:问题描述原因分析:解决方案:第一种:修改后,只有当前生效,若是mysql服务重启,就会失效;

MySQL多列IN查询的实现

《MySQL多列IN查询的实现》多列IN查询是一种强大的筛选工具,它允许通过多字段组合快速过滤数据,本文主要介绍了MySQL多列IN查询的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析与优化1.

Linux修改pip和conda缓存路径的几种方法

《Linux修改pip和conda缓存路径的几种方法》在Python生态中,pip和conda是两种常见的软件包管理工具,它们在安装、更新和卸载软件包时都会使用缓存来提高效率,适当地修改它们的缓存路径... 目录一、pip 和 conda 的缓存机制1. pip 的缓存机制默认缓存路径2. conda 的缓

Linux修改pip临时目录方法的详解

《Linux修改pip临时目录方法的详解》在Linux系统中,pip在安装Python包时会使用临时目录(TMPDIR),但默认的临时目录可能会受到存储空间不足或权限问题的影响,所以本文将详细介绍如何... 目录引言一、为什么要修改 pip 的临时目录?1. 解决存储空间不足的问题2. 解决权限问题3. 提

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

Linux文件名修改方法大全

《Linux文件名修改方法大全》在Linux系统中,文件名修改是一个常见且重要的操作,文件名修改可以更好地管理文件和文件夹,使其更具可读性和有序性,本文将介绍三种在Linux系统下常用的文件名修改方法... 目录一、引言二、使用mv命令修改文件名三、使用rename命令修改文件名四、mv命令和rename命

mybatis-plus 实现查询表名动态修改的示例代码

《mybatis-plus实现查询表名动态修改的示例代码》通过MyBatis-Plus实现表名的动态替换,根据配置或入参选择不同的表,本文主要介绍了mybatis-plus实现查询表名动态修改的示... 目录实现数据库初始化依赖包配置读取类设置 myBATis-plus 插件测试通过 mybatis-plu