HDU-3074-Multiply game
HDU-3074-Multiply game
http://acm.hdu.edu.cn/showproblem.php?pid=3074
求区间元素的乘积,可以更新元素,线段树即可
#include<stdio.h> #include<string.h> #include<stdlib.h> #define Mod 1000000007 #define N 50005 int num[N]; struct cam { int x; //起点 int y; //终点 __int64 mul; //乘积 }list[N*4]; void build(int k,int x,int y) { int mid; list[k].x=x; list[k].y=y; if(list[k].x==list[k].y) { list[k].mul=num[x]; return; } mid=(x+y)/2; build(k<<1,x,mid); build(k<<1|1,mid+1,y); list[k].mul=(list[k<<1].mul*list[k<<1|1].mul)%Mod; } __int64 find(int k,int x,int y) { int mid; if(list[k].x==x&&list[k].y==y) return list[k].mul; mid=(list[k].x+list[k].y)/2; if(x>mid) return find(k<<1|1,x,y); else if(y<=mid) return find(k<<1,x,y); return (find(k<<1,x,mid)*find(k<<1|1,mid+1,y))%Mod; } void update(int k,int x,int y) { int mid; if(list[k].x==x&&list[k].y==x) { list[k].mul=y; return; } mid=(list[k].x+list[k].y)/2; if(x<=mid) update(k<<1,x,y); else update(k<<1|1,x,y); list[k].mul=(list[k<<1].mul*list[k<<1|1].mul)%Mod; } int main() { int i,t; int n,m; int c,a,b; scanf("%d",&t); while(t--) { scanf("%d",&n); for(i=1;i<=n;i++) scanf("%d",&num[i]); build(1,1,n); scanf("%d",&m); while(m--) { scanf("%d %d %d",&c,&a,&b); if(c==0) printf("%I64d\n",find(1,a,b)); else { num[a]=b; update(1,a,b); } } } return 0; }
posted on 2012-07-18 23:34 java课程设计例子 阅读(121) 评论(0) 编辑 收藏 举报