Description
Farmer John 决定给他的奶牛们照一张合影,他让 N (1 ≤ N ≤ 50,000) 头奶牛站成一条直线,每头牛都有它的坐标(范围: 0..1,000,000,000)和种族(0或1)。 一直以来 Farmer John 总是喜欢做一些非凡的事,当然这次照相也不例外。他只给一部分牛照相,并且这一组牛的阵容必须是“平衡的”。平衡的阵容,指的是在一组牛中,种族0和种族1的牛的数量相等。 请算出最广阔的区间,使这个区间内的牛阵容平衡。区间的大小为区间内最右边的牛的坐标减去最做边的牛的坐标。 输入中,每个种族至少有一头牛,没有两头牛的坐标相同。
Input
行 1: 一个整数: N 行 2..N + 1: 每行两个整数,为种族 ID 和 x 坐标。
Output
行 1: 一个整数,阵容平衡的最大的区间的大小。
Sample Input
7
0 11
1 10
1 25
1 12
1 4
0 13
1 22
0 11
1 10
1 25
1 12
1 4
0 13
1 22
Sample Output
11
输入说明
有7头牛,像这样在数轴上。
输入说明
有7头牛,像这样在数轴上。
我们用前缀和来维护,如果区间[i,j],平衡,那么1到i-1的前缀和和1到j的前缀和是相同的,那么易得,对于一个前缀和,我们只需要找到最后一个和它相同的前缀和就可以了。。。
而且记住要离散化。。。
![](https://images.cnblogs.com/OutliningIndicators/ContractedBlock.gif)
![](https://images.cnblogs.com/OutliningIndicators/ExpandedBlockStart.gif)
1 #include<iostream> 2 #include<cstdio> 3 #include<cstring> 4 #include<cmath> 5 #include<algorithm> 6 #include<queue> 7 #include<set> 8 #include<map> 9 #include<vector> 10 #define maxn 100010 11 #define maxm 500010 12 #define inf 10000000 13 #define ll long long 14 using namespace std; 15 struct cow{int id,w;}e[maxm]; 16 int f[maxm*2],a[maxm]; 17 bool cmp(cow a,cow b){ 18 return a.id<b.id; 19 } 20 int main(){ 21 int n; 22 scanf("%d",&n); 23 for(int i=1;i<=n;i++)scanf("%d%d",&e[i].w,&e[i].id); 24 sort(e+1,e+n+1,cmp); 25 memset(f,-1,sizeof(f)); 26 f[maxm]=0; 27 int ans=0; 28 for(int i=1;i<=n;i++){ 29 a[i]=a[i-1]+(e[i].w?1:-1); 30 if(f[a[i]+maxm]!=-1){ 31 ans=max(ans,e[i].id-e[f[a[i]+maxm]+1].id); 32 }else{ 33 f[a[i]+maxm]=i; 34 } 35 } 36 printf("%d",ans); 37 return 0; 38 }