hdu 4908 BestCoder Sequence

Posted liguangsunls

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了hdu 4908 BestCoder Sequence相关的知识,希望对你有一定的参考价值。

比赛的时候绝逼整不出来啊。看了别人的blog,才理解什么解法

參考:http://blog.csdn.net/hcbbt/article/details/38377815

写的言简意赅

题目给出中位数,求有多少子串也是以m为中尉

思路:找出m的位置sign,然后向前找比m小。cou++。的index[]在对应的位置加一(等向m后面找的时候发现比m大的元素,构成了一个BestCoder Sequence,直接就sum+=index[])。比m大,cou--,也在的index[]在对应的位置加一(这样就把m前面比m大的数 也增加到准备数组index中,当m后面有比m大的时候sum+=index[],就把m前面比m大的元素也算上了,也构成了一个BestCoder Sequence)


/*************************************************************************
	> File Name: hdu4908.cpp
	> Author: yang
	> Mail:[email protected] 
	> Created Time: 2014年08月17日 星期日 17:11:59
 ************************************************************************/

#include<iostream>
#include<algorithm>
#include<memory.h>
#include<stdio.h>
using namespace std;
#define N 40010
int main(){
	int a[N],index[N],mid=N/2;
	int n,m;
	while(cin>>n>>m){
		int sign;
		for(int i=1;i<=n;i++){
			scanf("%d",&a[i]);
			if(a[i]==m) 
				sign=i;
		}
		int cou=0;
		memset(index,0,sizeof(index));
		for(int i=sign;i>=1;i--){
			if(a[i]>m) cou++;
			if(a[i]<m) cou--;
			index[mid+cou]++;
		}
		cou=0;
		int sum=0;
		for(int i=sign;i<=n;i++){
			if(a[i]>m) cou++;
			if(a[i]<m) cou--;
			sum+=index[mid-cou];
		}
		cout<<sum<<endl;
	}
}



以上是关于hdu 4908 BestCoder Sequence的主要内容,如果未能解决你的问题,请参考以下文章

hdu 4908 BestCoder Sequence

hdu 4908(思路题)

BestCoder Round #77 (div.2)(hdu5650,hdu5651(逆元),hdu5652(二分),hdu5653(dp))

BestCoder Round #69 (div.2)(hdu5611)

BestCoder Round #66 (div.2) hdu5592

BestCoder Round #73 (div.2)(hdu 5630)