前缀线性基模板 
#pragma  GCC optimize(2) 
#pragma  GCC optimize(3) 
#include  <bits/stdc++.h>  #define  mp make_pair 
#define  pb push_back 
#define  endl '\n' 
#define  mid (l + r >> 1) 
#define  lson rt << 1, l, mid 
#define  rson rt << 1 | 1, mid + 1, r 
#define  ls rt << 1 
#define  rs rt << 1 | 1 using  namespace  std; typedef  long  long  ll; 
typedef  unsigned  long  long  ull; 
typedef  pair< int ,  int >  pii; const  double  pi =  acos ( - 1.0 ) ; 
const  double  eps =  1e-7 ; 
const  int  inf =  0x3f3f3f3f ; inline  ll read ( )  { ll f =  1 ,  x =  0 ; char  c =  getchar ( ) ; while ( c <  '0'  ||  c >  '9' )  { if ( c ==  '-' )     f =  - 1 ; c =  getchar ( ) ; } while ( c >=  '0'  &&  c <=  '9' )  { x =  ( x <<  1 )  +  ( x <<  3 )  +  ( c ^  48 ) ; c =  getchar ( ) ; } return  f *  x; 
} const  int  N =  5e5  +  10 ; struct  PrefixLinearBasis { int  base[ N] [ 64 ] ,  pos[ N] [ 64 ] ,  num,  n =  30 ; void  init ( )  { for ( int  i =  0 ;  i <  N;  i++ )  { memset ( base[ i] ,  0 ,  sizeof  base[ i] ) ; memset ( pos[ i] ,  0 ,  sizeof  pos[ i] ) ; num =  0 ; } } void  add ( int  x)  { num++ ; for ( int  i =  0 ;  i <=  n;  i++ )  { base[ num] [ i]  =  base[ num -  1 ] [ i] ; pos[ num] [ i]  =  pos[ num -  1 ] [ i] ; } int  p =  num; for ( int  i =  n;  ~ i;  i-- )  { if ( x >>  i &  1 )  { if ( base[ num] [ i]  ==  0 )  { base[ num] [ i]  =  x; pos[ num] [ i]  =  p; return  ; } if ( pos[ num] [ i]  <  p)  { swap ( pos[ num] [ i] ,  p) ; swap ( base[ num] [ i] ,  x) ; } x ^ =  base[ num] [ i] ; } } } int  query_max ( int  l,  int  r)  { ll ans =  0 ; for ( int  i =  n;  ~ i;  i-- )  { if ( pos[ r] [ i]  <  l)  continue ; if ( ( ans ^  base[ r] [ i] )  >  ans)  { ans ^ =  base[ r] [ i] ; } } return  ans; } int  query_min ( int  l,  int  r)  { for ( int  i =  0 ;  i <=  n;  i++ )  { if ( pos[ r] [ i]  <  l)  continue ; if ( base[ r] [ i] )  return  base[ r] [ i] ; } } 
} ans; int  main ( )  { int  n =  read ( ) ; for ( int  i =  1 ;  i <=  n;  i++ )  { ll x =  read ( ) ; ans. add ( x) ; } int  m =  read ( ) ; for ( int  i =  1 ;  i <=  m;  i++ )  { int  l =  read ( ) ,  r =  read ( ) ; printf ( "%d\n" ,  ans. query_max ( l,  r) ) ; } return  0 ; 
}