Showing posts with label Segment Tree. Show all posts
Showing posts with label Segment Tree. Show all posts

[ SPOJ ] MULTQ3 - Multiples of 3

Author            : Anwar Jahid Ruman Hossain 
                    CSE, Batch - 6
                    BRUR.
Problem Statement : [ SPOJ ] MULTQ3 - Multiples of 3
Source            : Light OJ
Category          : Segment Tree
Algorithm         : Segment Tree
Verdict           : Time Limit Exceeded
  1. #include<bits/stdc++.h>  
  2. using namespace std;  
  3. #define ll long long int  
  4. #define mx 100005  
  5. int tree[mx*3][3];  
  6. int arr[mx];  
  7. void build_segment(int node,int left,int right){  
  8.     if(left==right){  
  9.         tree[node][0] = 1;  //divisible by 3 means %3 = 0  
  10.         tree[node][1] = 0;  // %3 = 1  
  11.         tree[node][2] = 0;  // %3 = 2  
  12.         return;  
  13.     }  
  14.     int mid=(left+right)/2;  
  15.     build_segment(node*2, left, mid); //left subtree build  
  16.     build_segment(node*2 + 1, mid+1, right); //right subtree build  
  17.     tree[node][0] = tree[node*2][0] + tree[node*2+1][0];  
  18.     tree[node][1] = tree[node*2][1] + tree[node*2+1][1];  
  19.     tree[node][2] = tree[node*2][2] + tree[node*2+1][2];  
  20. }  
  21.   
  22. int query_seqment(int node,int left,int right,int ia,int ib){  
  23.     if(right < ia || left > ib)return 0;  
  24.     if(ia <= left && right <= ib){  
  25.         return tree[node][0];//the divisible count  
  26.     }  
  27.     int mid=(left+right)/2;  
  28.     int cnt = 0;  
  29.     cnt += query_seqment(node*2 + 1, mid+1, right, ia, ib); //right subtree query  
  30.     cnt += query_seqment(node*2, left, mid, ia, ib); //left subtree query  
  31.     return cnt;  
  32. }  
  33. void update_segment(int node,int left,int right, int ia,int ib){  
  34.     if(ia>right || ib<left)  
  35.         return;  
  36.     if(left==right){  
  37.         int tmp = tree[node][0];  
  38.         tree[node][0] = tree[node][1];  
  39.         tree[node][1] = tree[node][2];  
  40.         tree[node][2] = tmp;  
  41.         return;  
  42.     }  
  43.     int mid=(left+right)/2;  
  44.     update_segment(node*2,left,mid,ia,ib);  
  45.     update_segment(node*2+1,mid+1,right,ia,ib);  
  46.     tree[node][0] = tree[node*2][0] + tree[node*2+1][0];  
  47.     tree[node][1] = tree[node*2][1] + tree[node*2+1][1];  
  48.     tree[node][2] = tree[node*2][2] + tree[node*2+1][2];  
  49. }  
  50. int main(){  
  51.     ios::sync_with_stdio(0); cin.tie(0); cout.tie(0);  
  52.     //freopen("input.txt","r",stdin);  
  53.     //freopen("output.txt","w",stdout);  
  54.     int n,q;  
  55.     while(scanf("%d%d",&n,&q)!=EOF){  
  56.         build_segment(1,1,n);  
  57.         int op,ia,ib;  
  58.         for(int i=1;i<=q;i++){  
  59.             scanf("%d%d%d",&op,&ia,&ib);  
  60.             if(op==1)  
  61.                 printf("%d\n",query_seqment(1,1,n,ia+1,ib+1));  
  62.             else if(op==0){  
  63.                 update_segment(1,1,n,ia+1,ib+1);  
  64.             }  
  65.         }  
  66.     }  
  67.     return 0;  
  68. }  

[ LightOJ ] 1082- Array Queries

Author            : Anwar Jahid Ruman Hossain 
                    CSE, Batch - 6
                    BRUR.
Problem Statement : [ LightOJ ] 1082- Array Queries
Source            : Light OJ
Category          : Segment Tree
Algorithm         : Segment Tree
Verdict           : Accepted
  1. #include<bits/stdc++.h>  
  2. using namespace std;  
  3. #define ll long long int  
  4. #define mx 100005  
  5. int tree[mx*3];  
  6. int arr[mx];  
  7. void build_segment(int node,int left,int right){  
  8.     if(left==right){  
  9.         tree[node]=arr[left]; //leaf node value set  
  10.         //cout<<"Index "<<node<<": "<<tree[node]<<endl;  
  11.         return;  
  12.     }  
  13.     int mid=(left+right)/2;  
  14.     build_segment(node*2, left, mid); //left subtree build  
  15.     build_segment(node*2 + 1, mid+1, right); //right subtree build  
  16.     tree[node]=min(tree[node*2], tree[node*2 + 1]); //parent min value set  
  17.     //cout<<"IndexMin "<<node<<": "<<tree[node]<<endl;  
  18. }  
  19. int query_seqment(int node,int left,int right,int ia,int ib){  
  20.   
  21.     if(ia>right || ib<left)  
  22.         return INT_MAX;  
  23.     if(left>=ia && right<=ib)  
  24.         return tree[node];  
  25.     int mid=(left+right)/2;  
  26.     int p=query_seqment(node*2, left, mid, ia, ib); //left parent query  
  27.     int q=query_seqment(node*2 + 1, mid+1, right, ia, ib); //right parent query  
  28.     return min(p,q);  
  29.   
  30.   
  31. }  
  32. int main(){  
  33.     //freopen("input.txt","r",stdin);  
  34.     //freopen("output.txt","w",stdout);  
  35.     int t;  
  36.     scanf("%d",&t);  
  37.     for(int tc=1;tc<=t;tc++){  
  38.         int n,q;  
  39.         scanf("%d%d",&n,&q);  
  40.         for(int i=1;i<=n;i++){  
  41.             scanf("%d",&arr[i]);  
  42.         }  
  43.         //root node, left most node, right most node  
  44.         build_segment(1,1,n);  
  45.         int ia,ib;  
  46.         printf("Case %d:\n",tc);  
  47.         for(int i=1;i<=q;i++){  
  48.             scanf("%d%d",&ia,&ib);  
  49.             //root, left most, right most, from node, to node  
  50.             printf("%d\n",query_seqment(1,1,n,ia,ib));  
  51.         }  
  52.     }  
  53.     return 0;  
  54. }