题目链接:http://acm.swust.edu.cn/problem/1094/

Time limit(ms): 1000      Memory limit(kb): 32768
 

中位数(又称中值,英语:Median),统计学中的专有名词,代表一个样本、种群或概率分布中的一个数值,其可将数值集合划分为相等的上下两部分。对于有限的数集,可以通过把所有观察值高低排序后找出正中间的一个作为中位数。如果观察值有偶数个,则中位数不唯一,通常取最中间的两个数值的平均数作为中位数。

Description

多组输入

第一行:一个正整数N (0<N<1000000)
第二行:N个正整数。(0=<A[i]<2^30)

Input

每组数据先输出”Case X:”,X表示测试数据的编号,从1开始。

第二行输出N个数,第i个数对应数组前i个值的中位数。(精确到小数点后一位)

Output
1
2
3
4
5
5
1 2 3 4 5
6
2 5 4 8 7 4
 
Sample Input
1
2
3
4
5
Case 1:
1.0 1.5 2.0 2.5 3.0
Case 2:
2.0 3.5 4.0 4.5 5.0 4.5
 
Sample Output
输出换行请使用\r\n

Hint
swust第10届校赛
 
 
解题思路:由于数据量太大,那么解题关键就在排序上面了,那么可以巧用堆排序,或者是使用容器 multiset(允许存在相同元素),那么就不会超时了。
 
下面是巧用容器的代码
 
 #include <iostream>
#include <set>
#include <cstdio>
using namespace std; #define rep(i,a,b) for(int i=a;i<=b;i++)
int t, n;
multiset<double>mpt; void mid_num(){
double x;
printf("Case %d:\r\n", ++t);
mpt.clear();
scanf("%lf", &x);
mpt.insert(x);
multiset <double> ::iterator it = mpt.begin();
printf("%.1lf", x);
rep(i, , n){
scanf("%lf", &x);
mpt.insert(x);
if (x < *it){
if (i & ) printf(" %.1lf", *(--it));
else {
multiset <double> ::iterator it1 = it;
printf(" %.1lf", (*it + *(--it1)) / 2.0);
}
}
else {
if (i & ) printf(" %.1lf", *it);
else {
++it;
multiset <double> ::iterator it1 = it;
printf(" %.1lf", (*it + *(--it1)) / 2.0); }
}
}
printf("\r\n");
} int main(){
while (~scanf("%d", &n))
mid_num();
return ;
}

堆排序的代码也贴出来吧(原谅我太懒没有优化这代码~~~)

 #include <stdio.h>
#include <string.h>
int lstack[], ltot, rstack[], rtot, mid;
int Max(int a, int b){
return a > b ? a : b;
}
int Min(int a, int b){
return a<b ? a : b;
}
void lup(int step){
while (step != ){
if (lstack[step]>lstack[step / ])lstack[step] ^= lstack[step / ] ^= lstack[step] ^= lstack[step / ];
else break;
step = step / ;
}
if (step == && lstack[] > mid) lstack[] ^= mid ^= lstack[] ^= mid;
}
void ldown(){
if (ltot > && mid < lstack[]) mid ^= lstack[] ^= mid ^= lstack[];
else return;
int step = ;
while (step * < ltot){
if (step * + >= ltot){
if (lstack[step] < lstack[step * ])
lstack[step] ^= lstack[step * ] ^= lstack[step] ^= lstack[step * ], step = step * ;
else return;
}
else{
if (lstack[step] <= lstack[step * ] && lstack[step * + ] <= lstack[step * ])
lstack[step] ^= lstack[step * ] ^= lstack[step] ^= lstack[step * ], step = step * ;
else if (lstack[step] <= lstack[step * + ] && lstack[step * ] <= lstack[step * + ])
lstack[step] ^= lstack[step * + ] ^= lstack[step] ^= lstack[step * + ], step = step * + ;
else return;
}
}
}
void rup(int step){
while (step != ){
if (rstack[step]<rstack[step / ])rstack[step] ^= rstack[step / ] ^= rstack[step] ^= rstack[step / ];
else break;
step = step / ;
}
if (step == && rstack[]<mid) rstack[] ^= mid ^= rstack[] ^= mid;
}
void rdown(){
if (rtot> && mid>rstack[]) mid ^= rstack[] ^= mid ^= rstack[];
else return;
int step = ;
while (step * < rtot){
if (step * + >= rtot){
if (rstack[step] > rstack[step * ])
rstack[step] ^= rstack[step * ] ^= rstack[step] ^= rstack[step * ], step = step * ;
else return;
}
else{
if (rstack[step] >= rstack[step * ] && rstack[step * + ] >= rstack[step * ])
rstack[step] ^= rstack[step * ] ^= rstack[step] ^= rstack[step * ], step = step * ;
else if (rstack[step] >= rstack[step * + ] && rstack[step * ] >= rstack[step * + ])
rstack[step] ^= rstack[step * + ] ^= rstack[step] ^= rstack[step * + ], step = step * + ;
else return;
}
}
}
int main()
{
int t = , n, i;
while (scanf("%d", &n) != EOF){
printf("Case %d:\r\n", t++);
scanf("%d", &mid);
ltot = rtot = ;
printf("%.1lf", (double)mid);
for (i = ; i < n; i++){
if (i % ){
scanf("%d", &lstack[ltot]);
lup(ltot);
rdown();
ltot++;
printf(" %.1lf", (mid + lstack[]) / 2.0);
}
else{
scanf("%d", &rstack[rtot]);
rup(rtot);
ldown();
rtot++;
printf(" %.1lf", (double)mid);
}
}
printf("\r\n");
}
return ;
}

[Swust OJ 1094]--中位数(巧用set,堆排序)的更多相关文章

  1. [Swust OJ 404]--最小代价树(动态规划)

    题目链接:http://acm.swust.edu.cn/problem/code/745255/ Time limit(ms): 1000 Memory limit(kb): 65535   Des ...

  2. [Swust OJ 649]--NBA Finals(dp,后台略(hen)坑)

    题目链接:http://acm.swust.edu.cn/problem/649/ Time limit(ms): 1000 Memory limit(kb): 65535 Consider two ...

  3. SWUST OJ NBA Finals(0649)

    NBA Finals(0649) Time limit(ms): 1000 Memory limit(kb): 65535 Submission: 404 Accepted: 128   Descri ...

  4. [Swust OJ 746]--点在线上(线段树解法及巧解)

    题目链接:http://acm.swust.edu.cn/problem/746/ Time limit(ms): 1000 Memory limit(kb): 65535   fate是一个数学大牛 ...

  5. [Swust OJ 1026]--Egg pain's hzf

      题目链接:http://acm.swust.edu.cn/problem/1026/     Time limit(ms): 3000 Memory limit(kb): 65535   hzf ...

  6. [swustoj 1094] 中位数

    中位数(1094) 问题描述 中位数(又称中值,英语:Median),统计学中的专有名词,代表一个样本.种群或概率分布中的一个数值,其可将数值集合划分为相等的上下两部分.对于有限的数集,可以通过把所有 ...

  7. 九度OJ 1371 最小的K个数 -- 堆排序

    题目地址:http://ac.jobdu.com/problem.php?pid=1371 题目描述: 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4 ...

  8. [Swust OJ 1023]--Escape(带点其他状态的BFS)

    解题思路:http://acm.swust.edu.cn/problem/1023/ Time limit(ms): 5000 Memory limit(kb): 65535     Descript ...

  9. [Swust OJ 1125]--又见GCD(数论,素数表存贮因子)

    题目链接:http://acm.swust.edu.cn/problem/1125/ Time limit(ms): 1000 Memory limit(kb): 65535   Descriptio ...

随机推荐

  1. Vijos 1083 小白逛公园(线段树)

    线段树,每个结点维护区间内的最大值M,和sum,最大前缀和lm,最大后缀和rm. 若要求区间为[a,b],则答案max(此区间M,左儿子M,右儿子M,左儿子rm+右儿子lm). ----------- ...

  2. Ajax学习之小结

    ajax: * 同步交互和异步交互:  * 同步交互:客户端发送请求——>等待服务器端处理——>接收响应,这个过程客户端不能做任何其他事情,这种模式叫做同步交互  * 异步交互:客户端发送 ...

  3. 5.6.2 Number类型

    Number是与数字对应的引用类型.要创建Number对象,可以在调用Number构造函数时向其中传递相应的数值.例如: var numberObject=new Number(10); 与Boole ...

  4. thinkphp phpexcel导入

    上次做了一个基于tp3.2.3的phpexcel导出,这次是phpexcel导入,准备材料phpexcel(不知道下载地址的查看我上一篇博文),虽说是基于thinkphp3.2.3来的,也只不过是引入 ...

  5. INDEX相关

    1.索引应该建立在WHERE子句经常用到的表列上,如果在大表上频率使用某列或者某几列作为条件执行检索操作,并且检索的行数低于总行数的15%,那么应该考虑在该几行上添加索引. 2.为了提高多表连接的性能 ...

  6. 关于block 用法

    Block  Apple 在C, Objective-C, C++加上Block這個延申用法.目前只有Mac 10.6 和iOS 4有支援.Block是由一堆可執行的程式組成,也可以稱做沒有名字的Fu ...

  7. verilog中读取文件中的字符串_modelsim高级仿真

    今天给个程序大家玩玩.因为今天遇到一个问题,就是要向UART发送指令,指令非常多,都是字符串.一直copy 函数 UART ("COMM_1");  UART ("COM ...

  8. SQL中采用Newtonsoft.Json处理json字符串

    原文 SQL中采用Newtonsoft.Json处理json字符串 使用环境: SQL Server2005; VS2010; 关于SQL中部署CLR程序集的方法,网上一搜一大把,需要了解的自行查阅, ...

  9. NeHe OpenGL lession 4

    // lession4.c #include <OpenGL/OpenGL.h> #include <GLUT/GLUT.h> #include <stdio.h> ...

  10. 转帖:Html.BeginForm

    Html.BeginForm与Ajax.BeginForm都是MVC架构中的表单元素,它们从字面上可以看到区别,即Html.BeginForm是普通的表单提交,而Ajax.BeginForm是支持异步 ...