线段树;
// 离散化的线段树;
#include < stdio.h >
#include < algorithm >
#include < memory.h >
using namespace std;
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
const int MAX = 1100000 ;
int p[ 3 * MAX];
int b[MAX];
int c[MAX];
int q[ 3 * MAX];
int Min[MAX];
int Max[MAX];
class IntervalTree
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
public :
int n;
IntervalTree();
void set ( int x);
int InsOrDel( int x, int test);
int FMAX();
int FMIN();
int Find( int x);
} ;
IntervalTree::IntervalTree()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
memset(p, 0 , sizeof (p));
}
void IntervalTree:: set ( int m)
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
n = m;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
/**//**/ /**//* initial n to the smallest number;
int k=Insert(1,1);
for(int i=1;i<=k;i*=2)
p[i]=n;
*/
}
int IntervalTree::InsOrDel( int x, int test) // test=1,add;test=0,delete;
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
int left = 0 ,right = n;
int k = 1 ;
int mid;
while (left < right)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
mid = (left + right) >> 1 ;
if (test > 0 )
p[k] ++ ;
else p[k] -- ;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
if (x <= c[mid])
{
k <<= 1 ;
right = mid;
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
else
{
k <<= 1 ;
k ++ ;
left = mid + 1 ;
}
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
if (test > 0 )
{
p[k] ++ ;
q[k] = x;
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
else
{
p[k] -- ;
}
return k;
}
int IntervalTree::FMAX() // find the max;
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
int k;
k = 1 ;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
while (p[ 2 * k] > 0 || p[ 2 * k + 1 ] > 0 )
{
if (p[ 2 * k + 1 ] > 0 )k = 2 * k + 1 ;
else k = 2 * k;
}
return q[k];
}
int IntervalTree::FMIN() // find the min;
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
int k;
k = 1 ;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
while (p[ 2 * k] > 0 || p[ 2 * k + 1 ] > 0 )
{
if (p[ 2 * k] > 0 )k = 2 * k;
else k = 2 * k + 1 ;
}
return q[k];
}
int IntervalTree::Find( int t) // Find the index of t;
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
int left = 1 ,right = n;
int mid;
int k = 1 ;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
while (left < right)
{
mid = (left + right) >> 1 ;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
if (t <= p[k])
{
k <<= 1 ;
right = mid;
}
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
else
{
t -= p[k];
k <<= 1 ;
k ++ ;
left = mid + 1 ;
}
}
mid = (left + right) >> 1 ;
if (p[mid] == t) return mid;
else return - 1 ; // t isn't in the tree;
}
int main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
IntervalTree a;
int l,i;
int max,min;
int k,n;
int m;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
while (scanf( " %d%d " , & n, & k) != EOF)
{
memset(p, 0 , sizeof (p));
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
for (i = 0 ;i < n;i ++ )
{
scanf( " %d " ,b + i);
c[i] = b[i];
}
sort(c,c + n);
// 离散化,相同的点合并;
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
for (i = 0 ,m = 0 ;i < n;i ++ ,m ++ )
{
while (i < n - 1 && c[i] == c[i + 1 ])i ++ ;
c[m] = c[i];
}
a. set (m - 1 ); // initial;
return 0 ;
}