hdu 3074 Multiply game
/* ***********************************************
Author :xryz
Email :523689985@qq.com
Created Time :4-30 21:25:25
File Name :Multiply game.cpp
************************************************ */
#include <stdio.h>
#include <string.h>
#include <iostream>
#include <algorithm>
#include <vector>
#include <queue>
#include <set>
#include <map>
#include <string>
#include <math.h>
#include <stdlib.h>
#include <time.h>
using namespace std;
const int mod=1000000007;
struct node
{
int left,right;
long long int sum;
} t[200000+5];
int a[50000+24];
void make(int id,int l,int r)//建树
{
t[id].left=l;
t[id].right=r;
if(l==r)
{
t[id].sum=a[l];
}
else
{
int mid=(l+r)/2;
make(id*2,l,mid);
make(id*2+1,mid+1,r);
t[id].sum=(t[id*2].sum*t[id*2+1].sum%mod);
}
}
void mult(int id,int pos,int p)//单点更新
{
int mid=(t[id].left+t[id].right)/2;
if(t[id].left==t[id].right&&t[id].left==pos)
{
t[id].sum=p;
return ;
}
else if(pos>mid) mult(id*2+1,pos,p);
else mult(id*2,pos,p);
t[id].sum=(t[id*2].sum*t[id*2+1].sum)%mod;
//if(t[id].sum==0) printf("%d\n",id);
}
long long int query(int l,int r,int id)//查询
{
if(t[id].left==l&&t[id].right==r)
return t[id].sum;
else
{
int mid=(t[id].left+t[id].right)/2;
if(r<=mid) return query(l,r,id*2);
else if(l>mid) return query(l,r,id*2+1);
else
return (query(l,mid,id*2)*query(mid+1,r,id*2+1))%mod;
}
}
int main()
{
int T,cmd,i,n,k,t1,t2;
scanf("%d",&T);
while(T--)
{
scanf("%d",&n);
a[0]=1;
for(i=1; i<=n; i++) scanf("%d",&a[i]);
make(1,1,n);
scanf("%d",&k);
while(k--)
{
scanf("%d%d%d",&cmd,&t1,&t2);
if(cmd==1)
{
mult(1,t1,t2);
a[t1]=t2;
//int ans=query(2,5,1);printf("%d\n",ans);
}
else
{
int ans=query(t1,t2,1)%mod;
printf("%d\n",ans);
}
}
}
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。http://xiang578.top/