Pku 2528 Mayor's posters

Pku 2528 Mayor's posters
#include  < iostream >
#include 
< algorithm >

using   namespace  std;

#define  N 10010

struct  Node{
    
int  x, y;
    Node( 
int  a =   0 int  b =   0  ):x(a), y(b) {}
};

int   n, idx[N * 2 ], data[N * 2 ], pos;
Node d[N];

int  bfind(  int  v ){
    
int  left =   0 , right =  n *   2 ;
    
while ( left +   1 <  right ){
        
int  m =  (left +  right) >>   1 ;
        
if ( data[m] <  v ) left =  m;
        
else   if ( data[m] >  v ) right =  m;
        
else   return  idx[m];
    }
    
return  idx[left];
}

int  tb[N * 8 ], flag[N];
void  insert(  int  l,  int  r,  int  a,  int  b,  int  rt,  int  c ){
    
if ( l ==  a  &&  r ==  b ){
        tb[rt]
=  c;  return ; }
    
int  m =  (l +  r) >>   1 ;
    
if ( tb[rt] >   0  ){
        tb[rt
<< 1 ] =  tb[rt], tb[(rt << 1 ) + 1 ] =  tb[rt], tb[rt] =   0 ; }
    
if ( b <=  m ) insert( l, m, a, b, rt <<   1 , c );
    
else   if ( a >  m ) insert( m +   1 , r, a, b, (rt << 1 ) +   1 , c );
    
else {
        insert( l, m, a, m, rt
<<   1 , c );
        insert( m
+   1 , r, m +   1 , b, (rt << 1 ) +   1 , c ); }
}
void  calc(  int  l,  int  r,  int  rt ){
    
if ( tb[rt] >   0  ) { flag[ tb[rt] ] =   1 return ; }
    
else {
        
if ( l ==  r )  return ;
        
int  m =  (l +  r) >>   1 ;
        calc( l, m, rt
<<   1  );
        calc( m
+   1 , r, (rt << 1 ) +   1  );
    }
}

int  main(){
    
int  test;
    scanf(
" %d " , & test);
    
while ( test --  ){
        scanf(
" %d " , & n );
        
int  u, v;
        
for int  i =   0 ; i <  n;  ++ i ){
            scanf(
" %d%d " , & u, & v );
            d[i]
=  Node( u, v );
            data[i
<< 1 ] =  u, data[(i << 1 ) + 1 ] =  v;
        }
        sort( data, data
+  n *   2  );
        pos
=   1 ; idx[ 0 ] =   1 ;
        
for int  i =   1 ; i <  n *   2 ++ i )
        
if ( data[i] !=  data[i - 1 ] ) idx[i] =   ++ pos;
        
else   idx[i] =  pos;
        
        memset( tb, 
0 sizeof (tb) ); 
        memset( flag, 
0 sizeof (flag) );
        
for int  i =   0 ; i <  n;  ++ i ){
            u
=  bfind( d[i].x ), v =  bfind( d[i].y );
            insert( 
1 , pos, u, v,  1 , i +   1  );
        }
        calc( 
1 , pos,  1  );
        
int  ans =   0 ;
        
for int  i =   1 ; i <=  n;  ++ i )
        
if ( flag[i] ) ans ++ ;
        printf(
" %d\n " , ans );
    }
    
return   0 ;
}

你可能感兴趣的:(Pku 2528 Mayor's posters)