题号:NC14269
                        时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
            空间限制:C/C++/Rust/Pascal 128 M,其他语言256 M
             64bit IO Format: %lld
        
     
    题目描述
        
        
    
            
            考虑维护一个这样的问题:
 (1) 给出一个数组A,标号为1~n
 (2) 修改数组中的一个位置。
 (3) 询问区间[l,r]中所有子集的位运算and之和mod(109+7)。
 位运算and即为“pascal中的and”和“C/C++中的&”
 我们定义集合S={ l , l+1 , ... , r-1 , r}
 若集合T,T ∩ S = T,则称T为S的子集
 设f(T)=AT1 and AT2 and ... and ATk  (设k为T集大小,若k=0则f(T)=0) 
 所有子集的位运算and之和即为∑f(T)
 那么,现在问题来了。
                            输入描述:
                                                    第一行,一个正整数N
第二行,N个非负整数,为数组A
第三行,一个正整数M,为操作次数
接下来M行格式如下
修改操作: 1 x y,将Ax修改为y
询问操作: 2 l r,区间[l,r]中所有子集的位运算and之和 mod(109+7)
                                                                            输出描述:
                                                    对于每次询问输出一行,为该次询问的答案mod(109+7)。
long long 请使用lld
                                                                            
                        
                            示例1
                        
                        
                            
                                输入
                                复制
                                
                                
                                    3
1 2 3
6
2 1 3
1 1 2
2 1 3
2 2 3
1 2 5
2 1 3
                                 
                             
                            
                                                            
                                    说明
                                    
                                        第一次询问:
Answer =1+2+3+(1 and 2)+(1 and 3)+(2 and 3)+(1 and 2 and 3)
=1+2+3+0+1+2+0
=9
第二次询问:
Answer =2+2+3+(2 and 2)+(2 and 3)+(2 and 3)+(2 and 2 and 3)
=2+2+3+2+2+2+2
=15
第三次询问:
Answer =2+3+(2 and 3)
=2+3+2
=7
第四次询问:
Answer =2+5+3+(2 and 5)+(2 and 3)+(3 and 5)+(2 and 5 and 3)
=2+5+3+0+2+1+0
=13
                                     
                                 
                                                     
                     
                                                        备注:
                M,N≤105,Ai≤109