【nowcoder】珂朵莉的数列 (树状数组 逆序对)

这篇博客介绍了如何利用树状数组高效地解决珂朵莉数列问题,通过计算序列中每个元素后面小于它的元素之和,来确定逆序对的数量。文章详细讲解了思路,并提供了代码实现。
摘要由CSDN通过智能技术生成

珂朵莉的数列

题意

珂朵莉给了你一个序列,有 n × ( n + 1 ) 2 \frac{n\times(n+1)}2 2n×(n+1)个子区间,求出她们各自的逆序对个数,然后加起来输出。

思路

对于一个逆序对(l,r)而言,它属于 ( n − r + 1 ) ∗ l (n-r+1)*l nr+1l个区间,理由如下,在这个逆序对左边有l-1个数,右边有n-r个数,它所属的区间可以有它左右各选取0个或多个数组成,因此它所属于的区间数为 ( n − r + 1 ) ∗ l

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值