题面 显然我们需要考虑每一个区间,而这个问题显然我们都会做,这不就是这道题么,也就是说假如中位数是$mid$,区间和是$sum$,那么代价就是$\sum\limits_{i=l}^r |mid-num[i]|$ 所以现在我们要维护这样的一个数据结构:支持删除/插入一个数,查询中位数和查询区间和 线段树?平衡树?写不来写不来,对顶堆即可解决 维护一个大根堆存区间中较小的一半数,小根堆存区间中较大的一半数,插入时比较一下两个堆的大小和堆顶元素(细节比较多,有一大坨讨论).查询中位数就非常方便了,直接…