ACM基础训练题解4302 丢失的牛

简单线段树插入和查询删除

 1 #include<iostream>
 2 #include<cstdlib>
 3 #include<cstring>
 4 using namespace std;
 5 int num[10000];
 6 int node[20000];
 7 int scale;
 8 void clear(int n){
 9     scale=1;
10     while(scale<=n+1)
11       scale=scale<<1;
12     memset(node,0,sizeof(node));
13     for(int i=scale+1;i<=scale+n;i++)
14         node[i]=1;
15     for(int i=scale-1;i>=1;i--)
16        node[i]=node[i+i]+node[i+i+1];
17     return ;
18 } 
19 int insert(int loc){
20     int p=1;
21     while(p<scale){
22         node[p]--;
23         if(node[p<<1]-loc>0)
24            p+=p;
25         else {
26             loc-=node[p<<1];
27             p=p+p+1;
28         }    
29     }
30     node[p]=0;
31     return (p-scale);
32 }
33 int main(){
34     int n;
35     cin>>n;
36     clear(n);
37     num[1]=0;
38     for(int i=2;i<=n;i++)
39        cin>>num[i];
40     for(int i=n;i>=1;i--)
41        num[i]=insert(num[i]);
42     for(int i=1;i<=n;i++)
43       cout<<num[i]<<endl;
44     return 0;
45 }
posted @ 2014-07-22 21:23  acPlay  阅读(333)  评论(0编辑  收藏  举报