树状数组(高级数据结构)-蓝桥杯
一、简介
树状数组 (Binary Indexed Tree,BIT),利用数的二进制特征进行检索的一种树状结构。
一种真正的高级数据结构: 二分思想、二叉树、位运算、前缀和。
高效!
代码极其简洁!
二、基本应用
数列a1,a2,....,an,操作:
单点修改:修改元素add(k,x): 把ak加上x。
求和:
sum (x) = a1 + ... + ax
区间和ai + ... + aj = sum(j) - sum(i-1)
三、不修改、只查询
数列aj, a2,..., an,求区间和: ai+ ...+aj
数列是静态的,用前缀和计算区间和,特别高效。
前缀和:sum[i]=a1+...+ ai
区间和: ai+...+aj = sum[j]-sum[i-1]
查询一次区间和,O(1)
代码


如果数列是动态的
修改元素add(k,x):把a加上x。
复杂度O(1)
求区间和:sum(j) - sum(i-1)
复杂度:O(n)--------->效率低
四、动态修改、求区间和: 用树状数组
数列是动态的
修改元素add(k,x):把ak加上x。
求区间和:sum(j) - sum(i-1)
复杂度都是: O(logn)
代码

五、从二叉树到树状数组

六、神奇的lowbit(x)操作
语法:lowbit(x)=x &-x
功能:找到x的二进制数的最后一个1

七、tree[ ]数组
从lowbit(x)推出tree[ ]数组,所有的计算都基于tree[ ],令m =lowbit(x)。
定义tree[x]:把ax和它前面共m个数相加。
例: lowbit(6)=2,有tree[6] = a5+a6。


横线中的黑色表示tree[x],等于横线上元素相加的和。

八、基于tree[ ]的计算
求和sum=a1 +...+ax
利用tree[ ]数组求sum,例如:
sum[8] = tree[8]
sum[7] = tree[7] + tree[6] + tree[4]
sum[9] = tree[9] + tree[8]
以上关系是如何得到的?借助lowbit(x)。
九、sum[ ]的计算
例: sum[7] = tree[7] + tree[6] + tree[4]
(1)从7开始,加上tree[7];
(2) 7 -lowbit(7)= 6,加上tree[6];
(3) 6 - lowbit(6) = 4,加上tree[4];
(4) 4-lowbit(4)= 0,结束。
sum()的复杂度?--------->O(logn)------非常好!

十、sum[ ]的更新
更改ax,和它相关的tree都会变化。
例如改变a3,那么tree[3]、tree[4]、tree[8]...都会改变。
影响哪些tree[ ]? 仍然利用lowbit(x)
(1) 更改tree[3];
(2) 3 +lowbit(3)= 4,更改tree[4];
(3) 4 +lowbit(4)=8,更改tree[8];
(4)直到最后的tree[n]。
复杂度?--------->O(logn)------非常好!

相关文章:
树状数组(高级数据结构)-蓝桥杯
一、简介树状数组 (Binary Indexed Tree,BIT),利用数的二进制特征进行检索的一种树状结构。一种真正的高级数据结构: 二分思想、二叉树、位运算、前缀和。高效!代码极其简洁!二、基本应用数列a1,a2,....,an,操作:单点修改…...
Flink-多流转换(Union、Connect、Join)
文章目录多流转换分流基本合流操作联合(Union)连接(Connect)基于时间的合流——双流联结(Join)窗口联结(Window Join)间隔联结(Interval Join)窗口同组联结&a…...
kubeadmin安装k8s集群
目录 一 、环境部署 1、服务器规划 2、环境准备 二、所有节点安装docker 1、配置yum源,安装docker 2、配置daemon.json文件 三、所有节点安装kubeadm、kubelet 和kubectl 四、部署k8s集群 1、查看初始化需要的镜像 2、导入镜像 3、初始化kubeadm 3.1 方…...
java3月train笔记
java笔记 day01 一、jdk和idea下载及安装(一般不建议装C盘): jdk:java开发环境 idea:开发工具(软件),用来编写代码的 苍老师文档服务器:doc.canglaoshi.org jdk下载&…...
Apollo Config原理浅析
文章目录1. 简介2. 基本功能3. Apollo关键功能实现原理3.1 框架整体原理3.1.1 Apollo角色3.1.2 框架执行原理3.1.3 整体组成3.2 细节实现3.2.1 Eureka和不同角色机器的关系3.2.2 Meta Server的作用3.2.3 ReleaseMessage消息实现原理3.2.4 Client的通信方式1. 简介 apollo是携程…...
Kubernetes二 Kubernetes之实战以及pod详解
Kubernetes入门 一 Kubernetes实战 本章节将介绍如何在kubernetes集群中部署一个nginx服务,并且能够对其进行访问。 1.1 Namespace Namespace是kubernetes系统中的一种非常重要资源,它的主要作用是用来实现多套环境的资源隔离或者多租户的资源隔离。…...
机械革命黑苹果改造计划第四番-外接显示器、win时间不正确问题解决
问题 1.无法外接显示器 最大的问题就是目前无法外接显示器,因为机械革命大多数型号笔记本电脑的HDMI、DP接口都是直接物理接在独显上的,内屏用核显外接显示器接独显,英伟达独显也是黑苹果无法驱动的,而且发现机械革命tpyec接口还…...
Linux docker(03)可使用GPU渲染的x11docker实战总结
该系列文章的目的旨在之前的章节基础上,使用x11docker构建一个可以使用GPU的docker容器。该容器可以用于3D图形渲染/XR 等使用GPU渲染的程序调试和运行。 0 why docker 为什么非要用x11docker,而不是其他的docker呢? 因为一般的docker是不…...
【Linux操作系统】【综合实验一 Linux操作基础】
文章目录一、实验目的二、实验要求三、实验内容四、实验报告要求一、实验目的 要求掌握Linux基础操作,熟悉Linux行界面,并明白操作的原理以及目的;熟悉Linux系统环境。 二、实验要求 通过这个第一阶段实验,要求掌握以下操作与相…...
关于监控服务器指标、CPU、内存、警报的一些解决方案
文章目录关于监控服务器指标、CPU、内存、警报的一些解决方案Prometheus Grafana 配置 IRIS / Cach 监控服务器Prometheus简介特点架构图Grafana简介特点配置流程自定义Prometheus接口定义配置 Exporter 监控服务器系统资源简介配置流程使用 Alertmanager报警简介配置流程基于…...
vue3全家桶技术栈基础(一)
在认识vue3全家桶之前,先简单回顾一下vue2的全家桶 一.在vue2中,全家桶技术栈 技术栈: vue2 vue-cli vuex3vue-router3webpack elementUI 1.vue-cli 脚手架构建vue项目,CLI 服务是构建于 webpack 和 webpack-dev-server构建快速生成一个vue2的开发项…...
群晖-第2章-设置HTTPS访问
群晖-第2章-设置HTTPS访问 本章介绍如何通过HTTPS访问群晖,前置要求是完成群晖-第1章-IPV6的DDNS中的内容,可以是IPV4也可以是IPV6,或者你有公网IP,直接添加DNS解析也可以。只要能通过域名访问到nas就行。 本文参考自群晖添加SS…...
005 利用fidder抓取app的api,获得股票数据
一、下载安装fidder 百度搜索fidder直接下载,按提示安装即可。 二、配置fidder 1. 打开fidder,选择tools——options。 2. 选择HTTPS选项卡,勾选前三项,然后点击右侧【actions】,选择【trust root certificate】&a…...
京东测试进阶之路:初入测试碎碎念篇
1、基本的测试用例设计方法 基本的测试用例设计方法(边界值分析、等价类划分等)。 业务和场景的积累,了解测试需求以及易出现的bug的地方。 多维角度设计测试用例(用户、业务流程、异常场景、代码逻辑)。 2、需求分析 …...
华为OD机试 - 乘积最大值(JavaScript) | 机试题+算法思路+考点+代码解析 【2023】
乘积最大值 题目 给定一个元素类型为小写字符串的数组 请计算两个没有相同字符的元素长度乘积的最大值 如果没有符合条件的两个元素返回0 输入 输入为一个半角逗号分割的小写字符串数组 2 <= 数组长度 <= 100 0 < 字符串长度 <= 50 输出 两个没有相同字符的元…...
Java并发知识点
文章目录1. start()和run()方法的区别?2. volatile关键字的作用?使用volatile能够保证:防止指令重排3. sleep方法和wait方法有什么区别?sleep()方法4. 如何停止一个正在运行的线程?方法一:方法二࿱…...
前端 ES6 环境下 require 动态引入图片以及问题
前端 ES6 环境下 require 动态引入图片以及问题require 引入图片方式打包体积对比总结ES6 环境中,通过 require 的方式引入图片很方便,一直以来也没有出过什么问题,后来项目中,需要动态引入图片。 require 动态引入也容易实现&am…...
PCL 欧氏聚类分割
文章目录 一、应用背景1、点云分割算法的属性2、点云分割的挑战二、实现过程三、主要函数及代码实现1、主要函数2、核心代码3、效果实现四、参考文献一、应用背景 1、点云分割算法的属性 1)鲁棒性,比如树木是具有与汽车相区别的特征的,当点云数据的特征数量增加时,分割算…...
一台服务器最大能支持多少条TCP连接
一、一台服务器最大能打开的文件数 1、限制参数 我们知道在Linux中一切皆文件,那么一台服务器最大能打开多少个文件呢?Linux上能打开的最大文件数量受三个参数影响,分别是: fs.file-max (系统级别参数)&am…...
Teradata退出中国,您可以相信中国数据库!
继Adobe、Tableau、Salesforce之后,2023年2月15日,数仓软件巨头Teradata宣布将逐步结束在中国的直接运营。数仓界的“黄埔军校”仓皇撤出中国市场给出的理由非常含蓄:Teradata对中国当前和未来商业环境的慎重评估,我们做了一个艰难…...
**边缘AI新范式:基于Python的轻量级模型部署实战与优化策略**在人工智能飞速发展的今天,**边缘计算**正
边缘AI新范式:基于Python的轻量级模型部署实战与优化策略 在人工智能飞速发展的今天,边缘计算正逐步成为智能系统落地的关键支撑。尤其在物联网(IoT)、工业自动化、智能安防等领域,将AI推理能力下沉到设备端已成为主流…...
Windows Server 2025 Hyper-V GPU虚拟化实战:从分区到实时迁移
1. Windows Server 2025 Hyper-V GPU虚拟化核心升级 如果你还在用传统方式给虚拟机独占分配GPU资源,那真的out了。Windows Server 2025带来的Hyper-V GPU虚拟化技术彻底改变了游戏规则。我最近在实验室环境实测发现,新版本通过**GPU分区(GPU-…...
Flutter中使用Drift实现跨平台数据库管理的实战指南
1. 为什么选择Drift作为Flutter数据库解决方案 第一次接触Flutter数据库选型时,我像大多数开发者一样纠结于sqflite和hive之间。直到项目需要同时支持Android、iOS和Web三端时,才发现Drift(原Moor)才是真正的跨平台利器。这个基于…...
MG811SpaceData:嵌入式端CO₂传感器四维建模与多气体解耦框架
1. MG811SpaceData 库技术解析:面向嵌入式系统的电化学气体传感器数据科学框架1.1 工程定位与设计哲学MG811SpaceData 并非传统意义上的传感器驱动库,而是一个嵌入式端轻量化数据科学框架,其核心目标是在资源受限的微控制器(如Ard…...
seo网络优化费用高的原因是什么_如何预算seo网络优化费用
SEO网络优化费用高的原因是什么_如何预算SEO网络优化费用 随着互联网的迅猛发展,搜索引擎优化(SEO)已成为每个企业提升在线可见度和吸引客户的重要手段。SEO网络优化费用高的问题时常困扰着初创企业和中小企业。为什么SEO网络优化费用如此高…...
Python flask django高校学生绩点成绩预警管理系统的设计与实现
目录同行可拿货,招校园代理 ,本人源头供货商功能模块分析预警规则设置数据可视化与报表系统安全与扩展技术实现参考项目技术支持源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作同行可拿货,招校园代理 ,本人源头供货商 功能模块分析 用户管…...
mui-datatables 高级定制:如何创建完全自定义的数据表格组件
mui-datatables 高级定制:如何创建完全自定义的数据表格组件 【免费下载链接】mui-datatables Datatables for React using Material-UI - https://www.material-ui-datatables.com 项目地址: https://gitcode.com/gh_mirrors/mu/mui-datatables mui-datatab…...
seo网站推广与社交媒体营销的结合_seo网站推广的投资回报率如何计算
SEO网站推广与社交媒体营销的结合:如何计算SEO网站推广的投资回报率 在当今的数字营销时代,SEO网站推广和社交媒体营销是两个不可或缺的组成部分。它们的结合可以帮助企业更好地吸引潜在客户,提高品牌知名度,并最终推动销售增长。…...
网站SEO与用户体验的关系是什么_高质量内容创作的技巧是什么
网站SEO与用户体验的关系是什么 在互联网时代,网站的成功往往取决于其在搜索引擎上的排名和用户体验的质量。这两者之间存在着密切的关系。一个高质量的网站不仅能在搜索结果中获得更好的排名,还能吸引并留住更多的用户。因此,了解网站SEO&a…...
终极网盘直链下载助手完整指南:八大平台一键解锁免费高速下载
终极网盘直链下载助手完整指南:八大平台一键解锁免费高速下载 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘…...
