[BZOJ 1303] [CQOI2009] 中位数图 【0.0】
题目链接:BZOJ - 1303
题目分析
首先,找到 b 的位置 Pos, 然后将数列中小于 b 的值赋为 -1 ,大于 b 的值赋为 1 。
从 b 向左扩展,不断算 Sum[i, b - 1] ,然后将 Cnt[Sum[i, b - 1]] 加一,这样就算出每个左边的Sum值有多少个了。
然后从 b 向右扩展,不断算 Sum[b + 1, i] ,然后 Ans += Cnt[Sum[b + 1, i]] 。
代码
#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <algorithm> using namespace std; const int MaxN = 100000 + 5; int n, b, num, Pos, Sum;
int A[MaxN], CntL[MaxN * 2]; typedef long long LL; LL Ans; int main()
{
scanf("%d%d", &n, &b);
for (int i = 1; i <= n; ++i) {
scanf("%d", &num);
if (num == b) {
A[i] = 0;
Pos = i;
continue;
}
if (num < b) A[i] = -1;
else A[i] = 1;
}
Sum = 0;
for (int i = Pos; i >= 1; --i) {
Sum += A[i];
++CntL[Sum + n];
}
Sum = 0; Ans = 0ll;
for (int i = Pos; i <= n; ++i) {
Sum += A[i];
Ans += (LL)CntL[-Sum + n];
}
printf("%lld\n", Ans);
return 0;
}
[BZOJ 1303] [CQOI2009] 中位数图 【0.0】的更多相关文章
- BZOJ 1303 CQOI2009 中位数图 水题
		
1303: [CQOI2009]中位数图 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2340 Solved: 1464[Submit][Statu ...
 - BZOJ 1303: [CQOI2009]中位数图【前缀和】
		
1303: [CQOI2009]中位数图 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2737 Solved: 1698[Submit][Statu ...
 - bzoj 1303: [CQOI2009]中位数图 数学
		
1303: [CQOI2009]中位数图 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/ ...
 - BZOJ 1303: [CQOI2009]中位数图 【水题】
		
给出1~n的一个排列,统计该排列有多少个长度为奇数的连续子序列的中位数是b.中位数是指把所有元素从小到大排列后,位于中间的数. Input 第一行为两个正整数n和b ,第二行为1~n 的排列. Out ...
 - BZOJ 1303: [CQOI2009]中位数图 问题转化_扫描_思维
		
将比 b 大的设成 1,比 b 小的设成 -1,开个桶左右扫描一下,乘法原理乘一乘就好了. 虽然一眼切,不过这个基于中位数的转化还是相当重要的.middle 那个主席树的题也需要该做法 Code: # ...
 - BZOJ 1303: [CQOI2009]中位数图(思路题)
		
传送门 解题思路 比较好想的思路题.首先肯定要把原序列转化一下,大于\(k\)的变成\(1\),小于\(k\)的变成\(-1\),然后求一个前缀和,还要用\(cnt[]\)记录一下前缀和每个数出现了几 ...
 - bzoj 1303: [CQOI2009]中位数图
		
题目链接 给n个数,一个值b, 统计所有以b为中位数的序列的个数.序列长度为奇数.数字在1-n之间, 每个数只出现一次. 如果一个数大于b, 那么将他赋值为1, 小于b赋值为-1, 记录数组中b出现的 ...
 - 【BZOJ】1303: [CQOI2009]中位数图(特殊的技巧)
		
http://www.lydsy.com/JudgeOnline/problem.php?id=1303 依旧是题解流,,,不看题解没法活,,,第一眼就是瞎搞,然后就是暴力,显然TLE..题解啊题解. ...
 - 1303: [CQOI2009]中位数图
		
早起一AC,整天萌萌哒. Problem: 1303 User: forgot93 Language: C++ Result: Accepted Time:56 ms Memory:2108 kb * ...
 
随机推荐
- UML 的基本组成
			
UML 是由UML构造块.规则.通用机制三部分组成的.而UML构造块由建模元素(事物).关系和图组成. 建模元素 建模元素是对模型中最具有代表性的成分的抽象.一般情况下,将建模元素分为结构元素.行为元 ...
 - ASP.NET中的文件上传大小限制的问题
			
一.文件大小限制的问题 首先我们来说一下如何解决ASP.NET中的文件上传大小限制的问题,我们知道在默认情况下ASP.NET的文件上传大小限制为2M,一般情况下,我们可以采用更改WEB.Config文 ...
 - HDU5047Sawtooth(java大数)
			
HDU5047Sawtooth(java大数) 题目链接 题目大意:在一个矩形内画n个"M".问如何画可以把这个矩形分成最多的区域. 给出这个区域的数目. 解题思路:最好的方式就是 ...
 - poj 2926 Requirements
			
点击打开poj 2926 思路: n维空间计算最远的曼哈顿距离 分析: 1 题目给定n个5维的点,要求最远的曼哈顿距离 2 求最远曼哈顿距离,对于一个n维的空间,其中两点的曼哈顿距离为:|x1-x2| ...
 - Access中出现改变字段“自己主动编号”类型,不能再改回来!(已解决)
			
Access中出现改变字段"自己主动编号"类型,不能再改回来! (已解决) 一次把access中的自增字段改成了数值,再改回自增时,提示:在表中输入了数据之后,则不能将不论什么字段 ...
 - [转][JAVA]定时任务之-Quartz使用篇
			
[BAT][JAVA]定时任务之-Quartz使用篇 定时任务之-Quartz使用篇 Quartz是OpenSymphony开源组织在Job scheduling领域又一个开源项目,它可以与J2EE与 ...
 - windows server 许可port或执行技巧
			
底:于windows serverserver于,部署应用程序,例如http当协议应用,当外网通http协议来访问网页,我们需要得到server入境许可,在访问者的浏览器网页内容足够的天赋正常显示,除 ...
 - windows服务,安装、启动、停止,配置,一个批处理文件搞定
			
相对而言,还是比较通用的吧,如果哪位仁兄有更好的实现方式,或者发现有不足之处,还请多多指教. @echo off echo.------------------------------------- ...
 - A除以B_2
			
本题要求计算A/B,其中A是不超过1000位的正整数,B是1位正整数.你需要输出商数Q和余数R,使得A = B * Q + R成立. 输入格式: 输入在1行中依次给出A和B,中间以1空格分隔. 输出格 ...
 - opencart 模块开发详解
			
opencart 模块开发详解 由 xiekanxiyang » 2013年 7月 11日 10:17 pm opencart 将页面分成若干模块, 每个模块可以有多个实例(可能这样说不是很恰当) 每 ...