依次读入一个整数序列,每当已经读入的整数个数为奇数时,输出已读入的整数构成的序列的中位数. #include<bits/stdc++.h> using namespace std; priority_queue<int> down; priority_queue<int,vector<int>,greater<int> > up; int main() { int t;scanf("%d",&t); while(t--…
依次读入一个整数序列,每当已经读入的整数个数为奇数时,输出已读入的整数构成的序列的中位数. 输入格式 第一行输入一个整数PP,代表后面数据集的个数,接下来若干行输入各个数据集. 每个数据集的第一行首先输入一个代表数据集的编号的整数. 然后输入一个整数MM,代表数据集中包含数据的个数,MM一定为奇数,数据之间用空格隔开. 数据集的剩余行由数据集的数据构成,每行包含10个数据,最后一行数据量可能少于10个,数据之间用空格隔开. 输出格式 对于每个数据集,第一行输出两个整数,分别代表数据集的编号以及输…
显然答案是将一段区间全部转化成了其中位数这样的话,需要维护一个数据结构支持查询当前所有数中位数对顶堆 用两个堆将 < 中位数的数放入大根堆将 > 中位数的数放入小根堆这样就会存在删除操作 删除的时候由于无法快速删除只需做个标记,标记该数被删除了一次并且堆的实际大小也应该另外记录维护 在标记时需要更改相应的堆的大小与权值答案就非常显然了 #include <bits/stdc++.h> using namespace std; #define gc getchar() inline…
题意:维护一个序列,两种操作 1.插入一个数 2.输出中位数(若长度为偶数,输出中间两个较小的那个) 对顶堆 维护一个小根堆,一个大根堆,大根堆存1--mid,小根堆存mid+1---n 这样堆顶必有中位数. 每次操作后维护两个堆元素数量,保证一个比另一个多1或相等 #include<cstdio> #include<iostream> #include<algorithm> #include<queue> using namespace std; #def…
Luogu P1168 Luogu P1801 UVA 501(洛谷Remote Judge) 前置知识:堆.优先队列STL的使用 对顶堆 是一种在线维护第\(k\)小的算法. 其实就是开两个堆,一个是大根堆,一个是小根堆.两个堆的根相对. 下面借助题目P1168进行详细分析. P1168 题意很好理解,不多作分析. 显然当\(i=1\)时,中位数就是\(a[1]\),记为\(mid\). 我们可以使用对顶堆,把比\(mid\)小的存入大根堆,比mid大的存入小根堆. 当我们已经加入奇数个元素时…
维护序列的动态中位数 第一次用链表做题..感觉指针指来指去也挺麻烦的.. 本题链表解法就是用数组模拟出一个链表,然后离线输入所有数,排序,按照输入顺序在链表里删除元素,一次性删掉两个,然后中位数指针对应移动即可 #include<iostream> #include<cstring> #include<cstdio> #include<algorithm> using namespace std; #define maxn 10004 struct smc{…
https://vjudge.net/problem/HDU-4261 对于一个长2000的数列划分最多25个块,每块代价为块内每个数与块内中位数差的绝对值之和,求最小总代价. 套路化地,设$f[i][j]$表示第$i$位,划了$j$块最小代价.然后dp.$O(n^3k)$不必说.($logn$和$k$看成同数量级,其实是$O(n^3(k+logn))$) 然后重点在于找中位数.上述暴力浪费在于每段区间中位数都要寻找一遍.可以用对顶堆(其实是不想写平衡树,或者不会更优秀,码量更小的玩意儿了),动…
由于我不会讲对顶堆,所以这里直接传上一个巨佬的学习笔记. 对顶堆其实还是很容易理解的,想这题的时候自己猜做法也能把没学过的对顶堆给想出来.后来了解,对顶堆主要还是动态的在线维护集合$K$大值.当然也可以带删除.但是可能退化,具体见另外一个题的说明. 像这题维护中位数就是要求第$N/2+1$大的数,所以可以让大根堆维护前$n/2$项,小根堆维护后$n/2+1$项(这里指排好序的).然后每次插入的时候及时调整即可,由于调整幅度不大,所以可以保证复杂度是$log$级别的. 代码被我写繁了因为我当时还不…
这道题是提高+省选-的难度,做出来的话对数据结构题目的理解会增加很多. 可以使用一种叫做对顶堆的东西,对顶堆是在线维护第n小的logn的算法.大概的思路是,假如我们要找的是第n小,我们就维护一个大小为n的(位于下方的)大顶堆,(位于上方的)小顶堆中每个元素都比大顶堆的大.在这道题中,n不变时每次有新的比他小的就把堆顶弹出到对顶(也就是小顶堆)的堆顶,每次n扩大的时候就从(上面的)小顶堆里取出堆顶放进大顶堆的堆顶…… 但是看样子应该其他平衡树也是可以解决这个问题的.比如支持快速名次的splay?还…
题意:多组数据,让你求出1~i(i为奇数&&i<=n)的中位数 思路:首先复杂度必为O(n)或O(nlogn)的(数据范围) 思索,如果题目要求1次中位数,好求!排个序,取a[(n+1)/2]就好了 [这道题n的前提是奇数哈] 可是???要求多次中位数,而且是每次加入两个数后,再求一次? 别慌!!!已知中位数的性质是跟数值的顺序有关的. 顺序?大家想一想有哪个数据结构能够动态维护数列顺序,并1次操作复杂度在O(logn)之内 那当然是堆[肯定用优先队列啦]^_^ 方式:[对顶堆] 不…