HDU1556 树状数组,线段树区间更新两种方法(主要树状数组)

2023-10-12 02:08

本文主要是介绍HDU1556 树状数组,线段树区间更新两种方法(主要树状数组),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

树状数组
#include <stdio.h>
#include <string.h>
const int MAXN=110000;
int n,c[MAXN];
int lowbit(int x)
//计算2^k
{x=x&-x;return x;
}
void update(int num,int val)
//向下查询,num是要更新的子节点,val是要修改的值
{while(num>0){c[num]+=val;num-=lowbit(num);}
}
int getSum(int num)
//向上统计每个区间被染色的次数
{int sum=0;while(num<=n){sum+=c[num];num+=lowbit(num);}return sum;
}
int main()
{int a,b;while(scanf("%d",&n),n){memset(c,0,sizeof(c));for(int i=0;i<n;i++){scanf("%d%d",&a,&b);//将b以下区间+1update(b,1);//将a以下区间-1update(a-1,-1);}for(int j=1;j<n;j++){printf("%d ",getSum(j));}printf("%d\n",getSum(n));}return 0;
}

线段树

#include <stdio.h>
#include <string.h>
#include <algorithm>
using namespace std;int ans[1000000],n;struct node
{int l,r,n;
} a[1000000];void init(int l,int r,int i)
{a[i].l = l;a[i].r = r;a[i].n = 0;if(l!=r){int mid = (l+r)>>1;init(l,mid,2*i);init(mid+1,r,2*i+1);}
}void insert(int i,int x,int y)
{if(a[i].l == x && a[i].r == y)//找到要刷的气球区间,更新其被刷的次数+1a[i].n++;else{int mid = (a[i].l+a[i].r)>>1;if(y<=mid)insert(2*i,x,y);else if(x>mid)insert(2*i+1,x,y);else{insert(2*i,x,mid);insert(2*i+1,mid+1,y);}}
}void add(int x)
{int i;for(i = a[x].l; i<=a[x].r; i++)//该区间所有编号都被刷了一次ans[i]+=a[x].n;if(a[x].l == a[x].r)return;add(2*x);add(2*x+1);
}int main()
{int x,y,i;while(~scanf("%d",&n),n){init(1,n,1);for(i = 1; i<=n; i++){scanf("%d%d",&x,&y);insert(1,x,y);}memset(ans,0,sizeof(ans));add(1);printf("%d",ans[1]);for(i = 2; i<=n; i++)printf(" %d",ans[i]);printf("\n");}return 0;
}

这里转载了两个别人的代码。感觉树状数组简单好多。。。

这篇关于HDU1556 树状数组,线段树区间更新两种方法(主要树状数组)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

便携式气象仪器的主要特点

TH-BQX9】便携式气象仪器,也称为便携式气象仪或便携式自动气象站,是一款高度集成、低功耗、可快速安装、便于野外监测使用的高精度自动气象观测设备。以下是关于便携式气象仪器的详细介绍:   主要特点   高精度与多功能:便携式气象仪器能够采集多种气象参数,包括但不限于风速、风向、温度、湿度、气压等,部分高级型号还能监测雨量和辐射等。数据采集与存储:配备微电脑气象数据采集仪,具有实时时钟、数据存

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++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

浅谈主机加固,六种有效的主机加固方法

在数字化时代,数据的价值不言而喻,但随之而来的安全威胁也日益严峻。从勒索病毒到内部泄露,企业的数据安全面临着前所未有的挑战。为了应对这些挑战,一种全新的主机加固解决方案应运而生。 MCK主机加固解决方案,采用先进的安全容器中间件技术,构建起一套内核级的纵深立体防护体系。这一体系突破了传统安全防护的局限,即使在管理员权限被恶意利用的情况下,也能确保服务器的安全稳定运行。 普适主机加固措施:

webm怎么转换成mp4?这几种方法超多人在用!

webm怎么转换成mp4?WebM作为一种新兴的视频编码格式,近年来逐渐进入大众视野,其背后承载着诸多优势,但同时也伴随着不容忽视的局限性,首要挑战在于其兼容性边界,尽管WebM已广泛适应于众多网站与软件平台,但在特定应用环境或老旧设备上,其兼容难题依旧凸显,为用户体验带来不便,再者,WebM格式的非普适性也体现在编辑流程上,由于它并非行业内的通用标准,编辑过程中可能会遭遇格式不兼容的障碍,导致操

hdu 1754 I Hate It(线段树,单点更新,区间最值)

题意是求一个线段中的最大数。 线段树的模板题,试用了一下交大的模板。效率有点略低。 代码: #include <stdio.h>#include <string.h>#define TREE_SIZE (1 << (20))//const int TREE_SIZE = 200000 + 10;int max(int a, int b){return a > b ? a :

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while