ACM学习历程—HDU5701 中位数计数(中位数 && 计数排序)
http://acm.hdu.edu.cn/showproblem.php?pid=5701
这是这次百度之星初赛2B的第六题。之前白山云做过类似的题,省赛完回来,我看了一下大概就有这样的思路:首先枚举每一个数k,计算以这个数为中位数的区间个数。关键是计算中位数的处理方法,将所有大于k的数置为1,小于k的数置为-1,等于k的数置为0。于是区间中位数大于k的区间和就大于0,小于k的小于0,等于k的等于0。而且每个数都不等,所以区间和为0的个数就是中位数为k的个数。
关于计算区间和为0的个数。如果维护前缀和sum的个数。那么维护到i的时候,以i为右区间值的区间必然是sum(i)-sum(j),那么区间和为0就是前面有多少个前缀和为sum(i)。然后区间必须是奇数长度,所以需要对奇偶区间维护前缀和,此外,还需要对sum==0的情况特判。
代码:
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <algorithm>
#include <set>
#include <map>
#include <queue>
#include <vector>
#include <string>
#define LL long long using namespace std; const int maxN = ;
int n, a[maxN], b[maxN];
int cnt[][maxN<<]; int cal(int k)
{
for (int i = ; i < n; ++i)
{
if (a[i] > k) b[i] = ;
else if (a[i] < k) b[i] = -;
else b[i] = ;
}
int ans = , sum = ;
memset(cnt, , sizeof(cnt));
for (int i = ; i < n; ++i)
{
sum += b[i];
ans += cnt[!(i&)][sum+maxN];
if (sum == && i% == ) ans++;
cnt[i&][sum+maxN]++;
}
return ans;
} void work()
{
for (int i = ; i < n; ++i)
{
if (i) printf(" ");
printf("%d", cal(a[i]));
}
printf("\n");
} int main()
{
//freopen("test.in", "r", stdin);
//freopen("test.out", "w", stdout);
while (scanf("%d", &n) != EOF)
{
for (int i = ; i < n; ++i) scanf("%d", &a[i]);
work();
}
return ;
}
ACM学习历程—HDU5701 中位数计数(中位数 && 计数排序)的更多相关文章
- ACM学习历程—NPU1086 随机数 2015年陕西省程序设计竞赛网络预赛(正式赛)C题 (计数排序 || set容器)
		Description 开学了,ACM队的边老板想在学校中请一些妹子一起做一项问卷调查,调查妹子们对ACM的了解情况,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100), ... 
- ACM学习历程—51NOD 1685 第K大区间2(二分 && 树状数组 && 中位数)
		http://www.51nod.com/contest/problem.html#!problemId=1685 这是这次BSG白山极客挑战赛的E题. 这题可以二分答案t. 关键在于,对于一个t,如 ... 
- ACM学习历程—HDU5396 Expression(递推 && 计数)
		Problem Description Teacher Mai has n numbers a1,a2,⋯,an and n−1 operators("+", "-&qu ... 
- ACM学习历程—Hihocoder 1178 计数(位运算 && set容器)(hihoCoder挑战赛12)
		时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 Rowdark是一个邪恶的魔法师.在他阅读大巫术师Lich的传记时,他发现一类黑魔法来召唤远古生物,鱼丸. 魔法n能召 ... 
- ACM学习历程—HDU 4726 Kia's Calculation( 贪心&&计数排序)
		DescriptionDoctor Ghee is teaching Kia how to calculate the sum of two integers. But Kia is so carel ... 
- 完成了C++作业,本博客现在开始全面记录acm学习历程,真正的acm之路,现在开始
		以下以目前遇到题目开始记录,按发布时间排序 ACM之递推递归 ACM之数学题 拓扑排序 ACM之最短路径做题笔记与记录 STL学习笔记不(定期更新) 八皇后问题解题报告 
- ACM学习历程—CodeForces 590A Median Smoothing(分类讨论 && 数学)
		题目链接:http://codeforces.com/problemset/problem/590/A 题目大意是给一个串,头和尾每次变换保持不变. 中间的a[i]变成a[i-1],a[i],a[i+ ... 
- ACM学习历程—HDU 5512 Pagodas(数学)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5512 学习菊苣的博客,只粘链接,不粘题目描述了. 题目大意就是给了初始的集合{a, b},然后取集合里 ... 
- ACM学习历程—HDU5521 Meeting(图论)
		题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5521 学习菊苣的博客,只粘链接,不粘题目描述了. 题目大意就是一个人从1开始走,一个人从n开始走.让最 ... 
随机推荐
- HCNP学习笔记之TCP中FLAGS字段SYN, FIN, ACK, PSH, RST, URG
			在TCP层,有个FLAGS字段,这个字段有以下几个标识:SYN, FIN, ACK, PSH, RST, URG. 其中,对于我们日常的分析有用的就是前面的五个字段. 含义: SYN 表示建立连接, ... 
- Python3:数字类型和字符串类型的相互转换
			Python3:数字类型和字符串类型的相互转换 一.python中字符串转换成数字 方法1: 类中进行导入:import string str='555'num=string.atoi(str)num ... 
- 华为交换机S5700系列配置镜像端口(1:1)
			配置本地镜像口(1:1) 组网需求 如图一所示,某公司行政部通过Switch与外部Internet通信,监控设备Server与Switch直连. 现在希望通过Server对行政部访问Internet的 ... 
- SpringBoot 事务隔离性和传播性
			propergation 传播性 Spring中七种Propagation类的事务属性详解: REQUIRED:支持当前事务,如果当前没有事务,就新建一个事务.这是最常见的选择. SUPPORTS ... 
- Android中获取并设置屏幕亮度
			最近在做一个Demo的时候用到了调节屏幕亮度的功能,于是上网搜索了一下,并且写了一个小Demo测试了一下,发现代码还是比较简单的.Android中的亮度调节,主要有三个方向,一个是针对于系统的亮度调节 ... 
- Hibernate -- 对象关系映射基础
- srm开发(基于ssh)(4)
			1 input处理内容补充 -在struts2里面有错误处理机制,当上传文件超过默认的大小,自动返回结果input -在struts.xml中配置input的返回结果 <!-- 配置input结 ... 
- appium自动化测试(五)
			1. 页面封装——理性判断 2. basepage——定位表达式的判断——要加上移动端的,加上上下左右滑动封装.toast可以封装.webview切换操作 3. 页面当中,所有元素定位——更换——移动 ... 
- KMP算法--C#版
			static void BuildTable(string subString, ref int[] next) { if (string.IsNullOrWhiteSpace(subString)) ... 
- Python正则表达式------进阶
			Python正则表达式 正则表达式是一个特殊的字符序列,它能帮助你方便的检查一个字符串是否与某种模式匹配. Python 自1.5版本起增加了re 模块,它提供 Perl 风格的正则表达式模式. re ... 
