树状数组求逆序对

news2025/1/11 14:20:23

由于树状数组的数学原理证明是很复杂的,使用树状数组基本只需要知道它可以支持单点修改和区间查询即可。并且要知道,树状数组的作用是维护一段支持修改的区间和。

树状数组结构

下面是树状数组的图示:
在这里插入图片描述

真正的数据是a[1]-a[8]这段数组。上面的tree数组是用来方便维护区间和的。
t[1]的lowbit是1,因此它的长度应该是1,所以t[1] = a[1]
t[2]的lowbit是2,因此它的长度应该是2,所以t[2] = t[1] + a[2]
t[3]的lowbit是1,因此它的长度应该是1,所以t[3] = a[3]
t[4]的lowbit是4,因此它的长度应该是4,所以t[4] = t[2] + t[3] + a[4]


依次类推下去,这就可以画出树状数组的结构图了。

单点查询为何这么写(不是数学证明)

关于单点修改,在图上的解释:比如我要在a[3]上加上常数K,那么我就必须要更新t[3],t[4]和t[8].因为3以后的前缀和都会因为这次的修改而改变。
并且我们发现一个规律,**3 + lowbit(3) = 4, 4 + lowbit(4) = 8.**因此我们可以写出修改的代码了。

void add(int x, int v)
{
    for (int i = x; i <= n; i += lowbit(i)) tr[i] += v;
}

区间查询为何这么写

关于区间查询,就是一个求前缀和的过程。由于我们刚刚说过的规律,当前下标 + lowbit(当前下标) = 下一个下标。 因此也可以写出对应的查询代码。

int query(int x)
{
    int res = 0;
    for (int i = x; i; i -= lowbit(i)) res += tr[i];
    return res;
}

上面就已经把基本的树状数组解释清楚了。现在开始用树状数组求逆序对了。

举个例子,比如现在有序列4321. 树状数组原序列为0000

  1. 在位置4上的数字自增1,现在序列为0001,现在对应的逆序对是前缀和(4)-前缀和(4) = 0,对应的含义就是,当只有一个数字4的时候,逆序对个数为0
  2. 在位置3上的数字自增1,现在序列为0011,现在对应的逆序对数量是前缀和(4)-前缀和(3) = 1,对应的含义是,当序列为43的时候,逆序对的数量是1
  3. 在位置2上的数字自增1,现在序列为0111,现在对应的逆序对数量是前缀和(4)-前缀和(2)= 2 ,对应的含义是,当序列为432的时候,逆序对的数量是2
  4. 在位置3上的数字自增1,现在序列为1111,现在对应的逆序对数量是前缀和(4)-前缀和(1)= 3 ,对应的含义是,当序列为4321的时候,逆序对的数量是3.
    5.3 + 2 + 1就是整体的逆序对数量,为6

这就是树状数组求逆序对的全部过程。

下面是对应的代码:(由于树状数组的数组下标从1开始,而输入的数据从0开始,所以全部让他自增1,并不会影响结果

for (int i = 1; i <= n; i++) {
    int x = ++a[i];
    add(x);
    ans += query(n) - query(x);
}

最后ans就是逆序对的数量。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/82772.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

零基础学FPGA(七):Altera FPGA管脚简述

日常唠嗑 同上一篇文章术语&#xff1a;Xilinx及Altera FPGA 配置名词区分&#xff0c;本篇文章也是短文&#xff0c;简述Altera FPGA芯片的管脚&#xff0c;供FPGA同行快速查阅信息。如果需要细入研究&#xff0c;可以网上检索看看&#xff0c;文章很多&#xff0c;写的也很详…

马哈鱼SQLFLow数据血缘分析器增量分析血缘任务

马哈鱼数据血缘分析器是一个分析数据血缘关系的平台&#xff0c;支持对大量复杂的数据快速准确的分析&#xff0c;支持分批增量分析血缘。 本文主要介绍如何利用马哈鱼增量分析任务。 使用步骤 登录sqlflow-api&#xff08;SQLFLow接口文档&#xff09;&#xff0c;http://1…

外汇天眼:本周监管状态已更新,以下平台请远离!

监管信息早知道&#xff01;外汇天眼将每周定期公布监管牌照状态发生变化的交易商&#xff0c;以供投资者参考&#xff0c;规避投资风险。 以下是监管牌照发生变动的交易商平台&#xff0c;注意警惕&#xff01; VS FX威胜 VS FX威胜&#xff0c;其宣称持有的美国NFA普通金融牌…

深入理解DOM

一、DOM 基本概念 DOM全称 Document Object Model&#xff0c;即文档对象模型&#xff0c;它允许脚本(js)控制Web页面、窗口和文档。 DOM 标准被分为 3 个不同的部分&#xff1a; 1、核心 DOM - 针对任何结构化文档的标准模型 2、XML DOM - 针对 XML 文档的标准模型 3、HT…

预制菜持续火热,食品制造企业如何利用APS自动排程实现生产管理标准化?

在今年预售榜单中&#xff0c;预制菜表现夺人眼球&#xff0c;在天猫“双11”活动的预售第一阶段强势出圈。在众多预售产品中&#xff0c;酸菜鱼已经成为消费者加购的爆品&#xff0c;成为雄霸“双11”预制菜预售榜单之首。 酸菜鱼是川菜的经典菜品&#xff0c;但现在已经突破地…

react源码中的fiber架构

先看一下FiberNode在源码中的样子 FiberNode // packages/react-reconciler/src/ReactFiber.old.js function FiberNode(tag: WorkTag, pendingProps: mixed, key: null | string, mode: TypeOfMode, ) {// Instancethis.tag tag;this.key key;this.elementType null;t…

Redis框架(六):大众点评项目 缓存更新策略 实现双写

大众点评项目 众点评项目 缓存更新策略 实现双写需求&#xff1a;缓存更新策略业务实现特殊情况展示SpringCloud章节复习已经过去&#xff0c;新的章节Redis开始了&#xff0c;这个章节中将会回顾Redis实战项目 大众点评 主要依照以下几个原则 基础实战的Demo和Coding上传到我…

GIS空间分析之密度分析

密度分析结果可以显示出点要素或线要素较为集中的地方。例如&#xff0c;每个城镇都可能有一个点值&#xff0c;这个点值表示该镇的人口总数&#xff0c;但是您想更多地了解人口随地区的分布情况。由于每个城镇内并非所有人都住在聚居点上&#xff0c;通过计算密度&#xff0c;…

网络安全学习路线,入门到入坟,史上最全网络安全学习路线整理

很多小伙伴在网上搜索网络安全时&#xff0c;会出来网络安全工程师这样一个职位&#xff0c;它的范围很广&#xff0c;只要是与网络安全挂钩的技术人员都算网络安全工程师&#xff0c;一些小伙伴就有疑问了&#xff0c;网络安全现在真的很火吗&#xff1f; 那么寒哥就带大家看…

美港探案:不理想的理想Q3,能否守得云开见月明?

12月9日&#xff0c;港股盘后理想汽车发布了2022年第三季度业绩报告。探员就迫不及待的去理想的官网上看了这份Q3业绩报告&#xff0c;整体数据很不理想&#xff0c;但是也都在探员的预料之内&#xff0c;但是探员对于理想依然是充满了热爱&#xff0c;在电动三傻中对理想也是情…

优美的曲线-turtlesim

从开环到闭环的旅程-CoCube 优美的曲线-译 2022年所公开博客案例所有项目&#xff0c;都在2020年之前完成&#xff0c;并且全部经过3轮以上测试。 当完美实现闭环之后&#xff0c;画曲线那就可以随心所欲啦。 想画什么&#xff0c;就能画什么。 核心代码&#xff1a; float …

DubboSPI使用以及使用方式源码解读

DubboSPI流程图 为什么Dubbo要自己实现SPI java spi 会一次性实例化扩展点所有实现&#xff0c;机制并不能根据获取自己想要的类 获取一个类的实现对象 javaSPI 具有局限性&#xff1a; 1、没法给实现类起别名 2、没法实现包装类。类似AOP的原理 3、没法实现自动注入 4、没法…

[附源码]Python计算机毕业设计SSM基于大数据的汽车流量监控(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

ESP32 ESP-IDF + LVGL + SquareLine Studio 设计 UI 界面

陈拓 2022/12/10-2022/12/12 1. 概述 关于SquareLine Studio&#xff0c;乐鑫官方的ESP技术文章有介绍&#xff1a;在 ESP 开发板上开发 UI 不再复杂 - 知乎如果您尝试过在没有图形库的情况下开发 UI&#xff0c;那么您一定知道这有多困难。幸运的是&#xff0c;由乐鑫芯片驱动…

线性代数---第六章---二次型

1二次型方的系数为主对角线上的元素 我起码要会如何根据二次型写矩阵A 2规范形是系数为1&#xff0c;-1&#xff0c;0的标准型 3二次型的正惯性指数和负惯性指数 4任一个n阶实对称阵&#xff0c;必然既相似又合同于对角阵 5用配方法化二次型为标准阵 6 正交变换得到的对角阵上…

【产品分析】从用户体验五要素分析——微信读书

本文从用户体验五要素&#xff1a;表现层面、框架层 、战略层、范围层、结构层&#xff0c;对微信读书进行了分析。 前言 互联网发展的速度也加速了知识更新的速度&#xff0c;也许今天你还手握焦点技能&#xff0c;明天就可能被遗忘在角落。一应俱全的网课、铺天盖地的资讯加…

Autosar PWM配置及使用

文章目录前言PWMPwmChannelPwmAssignedHwUnitPwmChannelIdPwmCoherentUpdatePwmDutycycleDefaultPwmIdleStatePwmNotificationPwmChannelClassPwmPeriodDefaultPwmPolarityPwmReferenceChannelPwmSafetySignalPwmShiftValuePWM输出偏移的使用PwmConfigurationOfOptApiServicesP…

Coreform Cubit (csimsoft Trelis)

Coreform Cubit (csimsoft Trelis) Coreform Cubit(csimsoft Trelis)是Coreform公司开发的最强大、最高效的工程工具之一。通常&#xff0c;公司都会启动自己的Mash项目。对于CFD分析&#xff0c;他们有FEA。这个软件可以开始你的工作&#xff0c;添加你自己的印第安形状&#…

2023年湖北建设厅七大员建筑八大员考试什么时候报名?甘建二

2023年湖北建设厅七大员建筑八大员考试什么时候报名&#xff1f; 建设厅七大员和建筑八大员有什么关系呢&#xff1f;有区别吗&#xff1f; 甘建二老师告诉你&#xff0c;建设厅七大员和建筑八大员没有区别&#xff0c;只是叫法不一样而已&#xff0c;都是一个东西。 七大员和…

Kunbernetes——二进制单节点部署

常见的k8s部署方式 1.Mini kube Minikube是一个工具&#xff0c;可以在本地快速运行一个单节点微型K8s&#xff0c;仅用于学习预览K8s的一些特性使用 部署地址: https://kubernetes.io/docs/setup/minikube 2.Kubeadmin Kubeadmin也是一个工具&#xff0c;提供kubeadm init和…