题解

1 条题解

  • 0
    @ 2014-06-10 15:50:17

    #include <cstdio>
    #include <cstring>

    #define rep( i , x ) for ( int i = 0 ; i ++ < x ; )
    #define REP( i , a , b ) for ( int i = a ; i <= b ; ++ i )

    #define left( t ) t -> left
    #define right( t ) t -> right
    #define L( t ) t -> l
    #define R( t ) t -> r
    #define lc( t ) t -> lc
    #define rc( t ) t -> rc
    #define C( t ) t -> c
    #define T( t ) t -> tag

    int ch ;

    void getint( int &t ) {
    for ( ch = getchar( ) ; ch < '0' || ch > '9' ; ch = getchar( ) ) ;
    t = ch - '0' ;
    for ( ch = getchar( ) ; ch >= '0' && ch <= '9' ; ch = getchar( ) ) t = 10 * t + ch - '0' ;
    }

    const int maxn = 501000 , maxv = 1510000 ;

    inline void upd( int &x , int &y , int &z , int a , int b , int c ) {
    z += c , z -= ( y == a ) ;
    y = b ;
    }

    struct node {

    node *left , *right ;
    int l , r , lc , rc , c , tag ;

    inline void pushdown( ) {
    if ( tag ) {
    lc = rc = tag , c = 1 ;
    if ( l < r ) left -> tag = tag , right -> tag = tag ;
    tag = 0 ;
    }
    }

    inline void update( ) {
    upd( lc = left -> lc , rc = left -> rc , c = left -> c , right -> lc , right -> rc , right -> c ) ;
    }

    } sgt[ maxv ] ;

    typedef node* np ;

    np pt = sgt , root ;

    int n , c , col[ maxn ] , m ;

    void build( int l , int r , np &t ) {
    t = pt ++ ;
    L( t ) = l , R( t ) = r , T( t ) = 0 ;
    if ( l == r ) {
    lc( t ) = rc( t ) = col[ l ] , C( t ) = 1 ;
    return ;
    }
    int mid = ( l + r ) >> 1 ;
    build( l , mid , left( t ) ) , build( mid + 1 , r , right( t ) ) ;
    t -> update( ) ;
    }

    void change( int l , int r , int c , np t ) {
    if ( l == L( t ) && r == R( t ) ) {
    T( t ) = c ; return ;
    }
    t -> pushdown( ) ;
    int mid = ( L( t ) + R( t ) ) >> 1 ;
    if ( r <= mid ) change( l , r , c , left( t ) ) ; else
    if ( l > mid ) change( l , r , c , right( t ) ) ; else {
    change( l , mid , c , left( t ) ) , change( mid + 1 , r , c , right( t ) ) ;
    }
    left( t ) -> pushdown( ) , right( t ) -> pushdown( ) ; t -> update( ) ;
    }

    void query( int l , int r , int &x , int &y , int &z , np t ) {
    t -> pushdown( ) ;
    if ( l == L( t ) && r == R( t ) ) {
    x = lc( t ) , y = rc( t ) , z = C( t ) ;
    return ;
    }
    int mid = ( L( t ) + R( t ) ) >> 1 ;
    if ( r <= mid ) query( l , r , x , y , z , left( t ) ) ; else
    if ( l > mid ) query( l , r , x , y , z , right( t ) ) ; else {
    int a , b , c ;
    query( l , mid , x , y , z , left( t ) ) , query( mid + 1 , r , a , b , c , right( t ) ) ;
    upd( x , y , z , a , b , c ) ;
    }
    }

    int getcol( int pos , np t ) {
    t -> pushdown( ) ;
    if ( L( t ) == R( t ) ) return lc( t ) ;
    int mid = ( L( t ) + R( t ) ) >> 1 ;
    return getcol( pos , pos <= mid ? left( t ) : right( t ) ) ;
    }

    int delta = 0 , dir = 1 ;

    inline void trans( int &pos ) {
    if ( dir == 1 || pos == 1 ) {
    pos -= delta ;
    if ( pos <= 0 ) pos += n ;
    } else {
    pos = n - pos + 2 - delta ;
    while ( pos <= 0 ) pos += n ;
    while ( pos > n ) pos -= n ;
    }
    }

    char s[ 10 ] ;

    int main( ) {
    getint( n ) , getint( c ) ;
    rep( i , n ) getint( col[ i ] ) ;
    build( 1 , n , root ) ;
    getint( m ) ;
    int x , y , z , a , b , c , i , j , k ;
    while ( m -- ) {
    scanf( "%s" , s ) ;
    if ( s[ 0 ] == 'R' ) {
    getint( a ) ;
    delta = ( delta + a * dir + n ) % n ;
    } else if ( s[ 0 ] == 'F' ) {
    dir *= - 1 ;
    } else if ( s[ 0 ] == 'S' ) {
    getint( x ) , getint( y ) ;
    trans( x ) , trans( y ) ;
    a = getcol( x , root ) , b = getcol( y , root ) ;
    change( x , x , b , root ) , change( y , y , a , root ) ;
    } else if ( s[ 0 ] == 'P' ) {
    getint( x ) , getint( y ) , getint( z ) ;
    trans( x ) , trans( y ) ;
    if ( x < y ) {
    if ( dir == 1 ) change( x , y , z , root ) ; else {
    change( 1 , x , z , root ) , change( y , n , z , root ) ;
    }
    } else if ( x > y ) {
    if ( dir == - 1 ) change( y , x , z , root ) ; else {
    change( 1 , y , z , root ) , change( x , n , z , root ) ;
    }
    } else change( x , x , z , root ) ;
    } else if ( strlen( s ) == 1 ) {
    query( 1 , n , x , y , z , root ) ;
    if ( z == 1 ) printf( "%d\n" , 1 ) ; else printf( "%d\n" , z - ( x == y ) ) ;
    } else {
    getint( x ) , getint( y ) ;
    trans( x ) , trans( y ) ;
    if ( x < y ) {
    if ( dir == 1 ) query( x , y , a , b , c , root ) ; else {
    query( y , n , a , b , c , root ) , query( 1 , x , i , j , k , root ) ;
    upd( a , b , c , i , j , k ) ;
    }
    } else if ( x > y ) {
    if ( dir == - 1 ) query( y , x , a , b , c , root ) ; else {
    query( x , n , a , b , c , root ) , query( 1 , y , i , j , k , root ) ;
    upd( a , b , c , i , j , k ) ;
    }
    } else {
    query( x , x , a , b , c , root ) ;
    }
    printf( "%d\n" , c ) ;
    }
    }
    return 0 ;
    }

  • 1

信息

ID
1828
难度
5
分类
(无)
标签
递交数
117
已通过
43
通过率
37%
被复制
2
上传者