中位数

Posted hehe54321

tags:

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

https://www.nowcoder.com/acm/contest/172/A

区间的中位数为:最大的数,使得 区间内>=x的数个数 > <x的数个数

二分答案x,把>=x的数标为1,<x的数标为-1,得到数组b,b数组的前缀和为数组c,那么就是要判断是否存在(0<=l,r<=n,r-l>=len)满足c[r]-c[l]>0;通过前缀最小值很容易完成

技术分享图片
 1 #include<cstdio>
 2 #include<algorithm>
 3 #include<cstring>
 4 #include<vector>
 5 using namespace std;
 6 #define fi first
 7 #define se second
 8 #define mp make_pair
 9 #define pb push_back
10 typedef long long ll;
11 typedef unsigned long long ull;
12 typedef pair<int,int> pii;
13 int n,len;
14 int a[101000],b[101000],c[101000];
15 bool judge(int x)
16 {
17     int i;
18     for(i=1;i<=n;i++)    b[i]=(a[i]>=x)?1:-1,b[i]+=b[i-1];
19     //for(i=1;i<=n;i++)  printf("%d ",b[i]);
20     //puts("");
21     //判断是否存在l,r,(r-l>=len),b[r]>b[l]
22     c[0]=b[0];
23     for(i=1;i<=n;i++)    c[i]=min(c[i-1],b[i]);
24     for(i=len;i<=n;i++)
25         if(b[i]>c[i-len])
26             return 1;
27     return 0;
28 }
29 int main()
30 {
31     int i,l,r,mid;
32     scanf("%d%d",&n,&len);
33     for(i=1;i<=n;i++)    scanf("%d",&a[i]);
34     l=1;r=1e9;
35     while(l!=r)
36     {
37         mid=l+((r-l)>>1);
38         if(judge(mid+1))    l=mid+1;
39         else    r=mid;
40     }
41     printf("%d",l);
42     return 0;
43 }
View Code

 

以上是关于中位数的主要内容,如果未能解决你的问题,请参考以下文章

微信小程序代码片段

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段6——CSS选择器