设为首页 加入收藏

TOP

hdu 4908 BestCoder Sequence
2015-07-20 17:53:13 来源: 作者: 【 】 浏览:1
Tags:hdu 4908 BestCoder Sequence

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

?

题目给出中位数,求有多少子串也是以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
  
   
#include
   
     #include
    
      #include
     
       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++; if(a[i]
       
        

?

】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇maven assembly plugin使用 下一篇UVA 657-The die is cast(双重BF..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: