树状数组模板--Color the ball
Color the ball
N个气球排成一排,从左到右依次编号为1,2,3....N.每次给定2个整数a b(a <= b),lele便为骑上他的“小飞鸽"牌电动车从气球a开始到气球b依次给每个气球涂一次颜色。但是N次以后lele已经忘记了第I个气球已经涂过几次颜色了,你能帮他算出每个气球被涂过几次颜色吗?
Input
每个测试实例第一行为一个整数N,(N <= 100000).接下来的N行,每行包括2个整数a b(1 <= a <= b <= N)。
当N = 0,输入结束。
Output
每个测试实例输出一行,包括N个整数,第I个数代表第I个气球总共被涂色的次数。
Sample Input
Sample Output
1 1 1
3 2 1
思路不难,就是线段树||差分数组||普通树状数组||树状数组+差分的模板题
每次更新时区间各点+1,最后输出每个元素的值,总结来说就是区间更新+单点查询
TLE版本,单点修改,肯定超时,因为需要每次遍历左端点到右端点去更新,无法保持O(logn)的时间复杂度
普通正解:update数组表示从1到x每个数更新的次数,所以我们只需要update(L-1,-1)和update(R,1)表示[L,R]被更新的次数,相当于将[1,L-1]这个区间-1,再将[1,R]+1
差分+树状数组:在普通正解基础上,在每次修改区间时,利用差分数组的性质,只更新左端点L和R+1的位置
TLE:
#include<iostream> #include<cstring> #include<math.h> #include<stdlib.h> #include<cstring> #include<cstdio> #include<utility> #include<algorithm> #include<map> #define lowbit(i) ((i)&(-i)) using namespace std; typedef long long ll; inline int read(){ ,w=;; while(!isdigit(ch)){w|=ch=='-';ch=getchar();} )+(X<<)+(ch^),ch=getchar(); return w?-X:X; } /*------------------------------------------------------------------------*/ ; ll c[maxn];//树状数组 int n; void update(int x,int v){ for(int i=x;i<=n;i+=lowbit(i)){ c[i]+=v; } } ll getsum(int x){//前x个整数之和 ll sum=; ;i-=lowbit(i)){ sum+=c[i]; } return sum; } ll query(int l,int r){ ); } int main( ) { ios_base::sync_with_stdio(); cin.tie(); cout.tie(); //freopen("a.txt","r",stdin); //freopen("a.txt","w",stdout); while(cin>>n){ )break; memset(c,,sizeof(c)); int l,r; ;i<=;++i){ cin>>l>>r; for(int j=l;j<=r;++j){ update(j,); } } ;i<=n;++i){ cout<<query(i,i)<<" "; } cout<<endl; } ; }
正解:
#include<iostream> #include<cstring> #include<math.h> #include<stdlib.h> #include<cstring> #include<cstdio> #include<utility> #include<algorithm> #include<map> #define lowbit(i) ((i)&(-i)) using namespace std; typedef long long ll; inline int read(){ ,w=;; while(!isdigit(ch)){w|=ch=='-';ch=getchar();} )+(X<<)+(ch^),ch=getchar(); return w?-X:X; } /*------------------------------------------------------------------------*/ ; ll c[maxn];//树状数组 int n; void update(int x,int v){ ;i-=lowbit(i)){ c[i]+=v; } } ll getsum(int x){//求第i个整数的值 ll sum=; for(int i=x;i<=n;i+=lowbit(i)){ sum+=c[i]; } return sum; } ll query(int l,int r){ ); } int main( ) { ios_base::sync_with_stdio(); cin.tie(); cout.tie(); //freopen("a.txt","r",stdin); //freopen("a.txt","w",stdout); while(cin>>n){ )break; memset(c,,sizeof(c)); int l,r; ;i<=n;++i){ cin>>l>>r; update(r,); update(l-,-); } ;i<n;++i){ cout<<getsum(i)<<" "; } cout<<getsum(n)<<endl; } ; }
差分+树状数组
#include<iostream> #include<cstring> #include<math.h> #include<stdlib.h> #include<cstring> #include<cstdio> #include<utility> #include<algorithm> #include<map> #define lowbit(i) ((i)&(-i)) using namespace std; typedef long long ll; inline int read(){ ,w=;; while(!isdigit(ch)){w|=ch=='-';ch=getchar();} )+(X<<)+(ch^),ch=getchar(); return w?-X:X; } /*------------------------------------------------------------------------*/ ; ll c[maxn];//树状数组 int n; void update(int x,int v){ for(int i=x;i<=n;i+=lowbit(i)){ c[i]+=v; } } ll getsum(int x){ ll sum=; ;i-=lowbit(i)){//前x个整数之和 sum+=c[i]; } return sum; } ll query(int l,int r){ ); } int main( ) { ios_base::sync_with_stdio(); cin.tie(); cout.tie(); //freopen("a.txt","r",stdin); //freopen("a.txt","w",stdout); while(cin>>n){ )break; memset(c,,sizeof(c)); int l,r; ;i<=n;++i){ cin>>l>>r; //update(r,1); //update(l-1,-1); update(l,); update(r+,-); } /* 差分数组的性质:差分数组的前x个数的和就是x的值 */ ;i<n;++i){ cout<<getsum(i)<<" "; } cout<<getsum(n)<<endl; } ; }
树状数组模板--Color the ball的更多相关文章
- HDU 1166 敌兵布阵(线段树/树状数组模板题)
敌兵布阵 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- 树状数组模板(pascal) 洛谷P3374 【模板】树状数组1
题目描述 如题,已知一个数列,你需要进行下面两种操作: 1.将某一个数加上x 2.求出某区间每一个数的和 输入输出格式 输入格式: 第一行包含两个整数N.M,分别表示该数列数字的个数和操作的总个数. ...
- luogu3368树状数组模板2
题目链接:https://www.luogu.org/problemnew/show/P3368 题意:与模板1不同的是这题的操作是树状数组并不在行的区间更新和单点查找,如果按照模板1那样写肯定会T. ...
- HDU 1166 线段树模板&树状数组模板
HDU1166 上好的线段树模板&&树状数组模板 自己写的第一棵线段树&第一棵树状数组 莫名的兴奋 线段树: #include <cstdio> using nam ...
- 敌兵布阵 HDU - 1166 (树状数组模板题,线段树模板题)
思路:就是树状数组的模板题,利用的就是单点更新和区间求和是树状数组的强项时间复杂度为m*log(n) 没想到自己以前把这道题当线段树的单点更新刷了. 树状数组: #include<iostrea ...
- 2016 Multi-University Training Contest 4 Bubble Sort(树状数组模板)
Bubble Sort 题意: 给你一个1~n的排列,问冒泡排序过程中,数字i(1<=i<=n)所到达的最左位置与最右位置的差值的绝对值是多少 题解: 数字i多能到达的最左位置为min(s ...
- poj1195二维树状数组模板
二维树状数组和一维的也差不多,改一下add和query函数即可:即按行修改,行内单点修改即可 /* 二维树状数组,询问一个二维区间内的数之和 */ #include<iostream> # ...
- 敌兵布阵---hud1166(线段树或者树状数组模板)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1166 线段树中对某一点的值进行改变: #include<iostream> #includ ...
- 线段树&树状数组模板
树状数组: #include <bits/stdc++.h> using namespace std; ; struct binit { int a[MAXN], n; void modi ...
随机推荐
- Druid连接池和springJDbc框架-Java(新手)
Druid连接池: Druid 由阿里提供 安装步骤: 导包 durid1.0.9 jar包 定义配置文件 properties文件 名字任意位置也任意 加载文件 获得数据库连接池对象 通过Durid ...
- 利用JDBC工具类添加和查询数据-Java(新手)
JDBC工具类: 1 package cn.lxr.jdbclx; 2 3 import java.sql.*; 4 5 public class JDBCUtils { 6 private stat ...
- C# lock 语法糖实现原理--《.NET Core 底层入门》之自旋锁,互斥锁,混合锁,读写锁
在多线程环境中,多个线程可能会同时访问同一个资源,为了避免访问发生冲突,可以根据访问的复杂程度采取不同的措施 原子操作适用于简单的单个操作,无锁算法适用于相对简单的一连串操作,而线程锁适用于复杂的一连 ...
- SpringBoot的启动流程是怎样的?SpringBoot源码(七)
注:该源码分析对应SpringBoot版本为2.1.0.RELEASE 1 温故而知新 本篇接 SpringBoot内置的各种Starter是怎样构建的? SpringBoot源码(六) 温故而知新, ...
- docker安装mysql主从
docker安装mysql主从 启动主库: 1.docker run --name master -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -d mysql:5 ...
- python如何通过正则表达式一次性提取到一串字符中所有的汉字
1.python如何通过正则表达式一次性提取到一串字符中所有的汉字 https://blog.csdn.net/py0312/article/details/93999895 说明:字符串前的 “ r ...
- 华为云+NextCloud(私人云盘搭建)
这几天发现了牛客+华为云的返现活动,免费用一年,赶紧的去搞了一个折腾折腾.(相关软件下载链接在最下面) 噔噔噔!!! 102822985.png) 废话少说,开始搭建. 基础环境部署 Apache安装 ...
- Jmeter4.0之语言修改(二)
下载最新Jmeter后,解压后,点击jmeter.bat,启动后,界面显示的是英文,那如何切换到中文了,步骤是点击Options中的Choose Language,选择中文 但是关闭Jmeter再次启 ...
- SQL Server 创建链接服务器的脚本,自定义链路服务器的简短名称
USE [master]GO /****** Object: LinkedServer [SQL01] Script Date: 2020/4/9 11:51:17 ******/EXEC m ...
- 高性能/并发的保证-Netty在Redisson的应用
前言 Redisson Github: https://github.com/redisson/redisson Redisson 官网:https://redisson.pro/ Redis ...