首页 > 代码库 > hdu 4908 BestCoder Sequence
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:826123027@qq.com > 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; } }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。