zoukankan      html  css  js  c++  java
  • BZOJ1303 [CQOI2009]中位数图 其他

    欢迎访问~原文出处——博客园-zhouzhendong

    去博客园看该题解


    题目传送门 - BZOJ1303


    题意概括

      给出1~n的一个排列,统计该排列有多少个长度为奇数的连续子序列的中位数是b。中位数是指把所有元素从小到大排列后,位于中间的数。


    题解

      我们找到b的位置,比如为pos。

      然后往左,逐位统计比b小的,比b大的,差记为a。

      对于左边所有的位置,bar[a]++,搞 n × 2 个桶。然后右边一边扫过去,一边根据桶的记录统计即可。


    代码

    #include <cstring>
    #include <algorithm>
    #include <cstdio>
    #include <cstdlib>
    #include <cmath>
    using namespace std;
    typedef long long LL;
    const int N=100000+5;
    int n,k,pos,a[N],zero=N-5,bar[N*2];
    int main(){
    	scanf("%d%d",&n,&k);
    	for (int i=1;i<=n;i++){
    		scanf("%d",&a[i]);
    		if (a[i]==k)
    			pos=i;
    	}
    	memset(bar,0,sizeof bar);
    	LL ans=1;
    	for (int i=pos-1,cnt=0;i>=1;i--){
    		if (a[i]<k)
    			cnt++;
    		else
    			cnt--;
    		bar[cnt+zero]++;
    		if (cnt==0)
    			ans++;
    	}
    	for (int i=pos+1,cnt=0;i<=n;i++){
    		if (a[i]<k)
    			cnt--;
    		else
    			cnt++;
    		ans+=bar[cnt+zero];
    		if (cnt==0)
    			ans++;
    	}
    	printf("%lld",ans);
    	return 0;
    }
    

      

  • 相关阅读:
    Shell Sort 希尔排序
    Quick Sort 快速排序
    Merge Sort 归并排序
    Insertion Sort
    Bubble Sort
    dubbo的异常栈问题
    IoC 容器
    .Net Core集成RabbitMQ
    .NET CORE Skywalking的集成
    制造业的信息化之路
  • 原文地址:https://www.cnblogs.com/zhouzhendong/p/BZOJ1303.html
Copyright © 2011-2022 走看看