青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

pku 3225 區間 我對線段樹延遲標記的一些理解

這題網上結題報告應該很多了,我也不想多寫什么,但是寫完這題后,我對延遲標記的更新策略有了更新的理解
這題節點的結構應該算復雜的了
1 struct tree
2 {
3     int s,e;
4     char cover,del,turn,sta;
5 }st[65540*8];
其中除了狀態域,總共有3個延遲標記。合法的節點應該是至多存在一個延遲標記。所以我們在push_down的時候,當前節點至多有1個延遲標記,我們也要保證將該標記傳遞下去以后,兒子節點也要滿足至多存在一個延遲的約束,否則我們將無法處理木有優先級的多個標志重疊的情況。例如這題:
 1 void push(int pos)
 2 {
 3     if(st[pos].turn)
 4     {
 5         st[pos].sta=!st[pos].sta;
 6         st[pos].turn=0;
 7         if(st[pos].e!=st[pos].s)
 8         {
 9             if(st[L].cover) st[L].cover=0,st[L].del=1;
10             else if(st[L].del) st[L].cover=1,st[L].del=0;
11             else  st[L].turn=!st[L].turn;
12             if(st[R].cover) st[R].cover=0,st[R].del=1;
13             else if(st[R].del) st[R].cover=1,st[R].del=0;
14             else  st[R].turn=!st[R].turn;
15         }
16     }
17     else if(st[pos].cover)
18     {
19         st[pos].cover=0;
20         st[pos].sta=1;
21         if(st[pos].e!=st[pos].s)
22         {
23             st[L].cover=1;
24             st[L].del=0;
25             st[L].turn=0;
26             st[R].cover=1;
27             st[R].del=0;
28             st[R].turn=0;
29         }
30     }
31     else if(st[pos].del)
32     {
33         st[pos].del=0;
34         st[pos].sta=0;
35         if(st[pos].e!=st[pos].s)
36         {
37             st[L].cover=0;
38             st[L].turn=0;
39             st[L].del=1;
40             st[R].cover=0;
41             st[R].del=1;
42             st[R].turn=0;
43         }
44     }
45 }
所有操作函數的結構都應該是這樣的
1 void insert(int s,int e,int pos)
2 {
3     push(pos);
4     if(st[pos].s==s&&st[pos].e==e) st[pos].cover=1;
5     else if(e<=M) insert(s,e,L);
6     else if(s>=M+1) insert(s,e,R);
7     else insert(s,M,L),insert(M+1,e,R);
8 }
因為這題木有向上維護的過程,如果有的話,末尾要加上
push(L),push(R),update(pos);
所有線段樹的結構都是如此,更新策略也亦是如此,只要保證節點至多1個延遲標記 的性質,題目就不會錯。
最后,附上本題得完整代碼,感覺我寫的算清楚的了
  1 # include <stdio.h>
  2 # include <string.h>
  3 # include <stdlib.h>
  4 struct tree
  5 {
  6     int s,e;
  7     char cover,del,turn,sta;
  8 }st[65540*8];
  9 # define M ((st[pos].s+st[pos].e)>>1)
 10 # define L (pos<<1)
 11 # define R ((pos<<1)+1)
 12 void init(int s,int e,int pos)
 13 {
 14     st[pos].s=s;
 15     st[pos].e=e;
 16     st[pos].cover=st[pos].del=st[pos].turn=st[pos].sta=0;
 17     if(e!=s)
 18         init(s,M,L),init(M+1,e,R);
 19 }
 20 void push(int pos)
 21 {
 22     if(st[pos].turn)
 23     {
 24         st[pos].sta=!st[pos].sta;
 25         st[pos].turn=0;
 26         if(st[pos].e!=st[pos].s)
 27         {
 28             if(st[L].cover) st[L].cover=0,st[L].del=1;
 29             else if(st[L].del) st[L].cover=1,st[L].del=0;
 30             else  st[L].turn=!st[L].turn;
 31             if(st[R].cover) st[R].cover=0,st[R].del=1;
 32             else if(st[R].del) st[R].cover=1,st[R].del=0;
 33             else  st[R].turn=!st[R].turn;
 34         }
 35     }
 36     else if(st[pos].cover)
 37     {
 38         st[pos].cover=0;
 39         st[pos].sta=1;
 40         if(st[pos].e!=st[pos].s)
 41         {
 42             st[L].cover=1;
 43             st[L].del=0;
 44             st[L].turn=0;
 45             st[R].cover=1;
 46             st[R].del=0;
 47             st[R].turn=0;
 48         }
 49     }
 50     else if(st[pos].del)
 51     {
 52         st[pos].del=0;
 53         st[pos].sta=0;
 54         if(st[pos].e!=st[pos].s)
 55         {
 56             st[L].cover=0;
 57             st[L].turn=0;
 58             st[L].del=1;
 59             st[R].cover=0;
 60             st[R].del=1;
 61             st[R].turn=0;
 62         }
 63     }
 64 }
 65 void insert(int s,int e,int pos)
 66 {
 67     push(pos);
 68     if(st[pos].s==s&&st[pos].e==e) st[pos].cover=1;
 69     else if(e<=M) insert(s,e,L);
 70     else if(s>=M+1) insert(s,e,R);
 71     else insert(s,M,L),insert(M+1,e,R);
 72 }
 73 void clear(int s,int e,int pos)
 74 {
 75     push(pos);
 76     if(st[pos].s==s&&st[pos].e==e) st[pos].del=1;
 77     else if(e<=M) clear(s,e,L);
 78     else if(s>=M+1) clear(s,e,R);
 79     else clear(s,M,L),clear(M+1,e,R);
 80 }
 81 void turn(int s,int e,int pos)
 82 {
 83     push(pos);
 84     if(st[pos].s==s&&st[pos].e==e) st[pos].turn=!st[pos].turn;
 85     else if(e<=M) turn(s,e,L);
 86     else if(s>=M+1) turn(s,e,R);
 87     else turn(s,M,L),turn(M+1,e,R);
 88 }
 89 int quarry(int pos,int target)
 90 {
 91     push(pos);
 92     if(st[pos].s==target&&st[pos].e==target)
 93         return st[pos].turn?!st[pos].sta:st[pos].sta;
 94     else if(target>M) return st[pos].turn?!quarry(R,target):quarry(R,target);
 95     else return st[pos].turn?!quarry(L,target):quarry(L,target);
 96 }
 97 void print()
 98 {
 99     int i,last=-1,used=0;
100     for(i=0;i<=65540*2;i++)
101     {
102         if(quarry(1,i))
103         {
104             if(last==-1) last=i;
105             used=1;
106         }
107         else
108         {
109             if(last!=-1)
110             {
111                 printf("%c%d,%d%c ",last%2?'(':'[',last/2,(i-1)%2?(i-1)/2+1:(i-1)/2,(i-1)%2?')':']');
112                 last=-1;
113             }
114         }
115     }
116     if(!used) printf("empty set");
117     printf("\n");
118 }
119 int main()
120 {
121     
122     char jud[5];
123     init(0,65540*2,1);
124     while(scanf("%s",jud)!=EOF)
125     {
126         char str[128],type1,type2;
127         int num1,num2;
128         scanf("%s",str);
129         type1=(*str=='(');
130         type2=(str[strlen(str)-1]==')');
131         str[strlen(str)-1]='\0';
132         num1=atoi(strtok(str+1,","));
133         num2=atoi(strtok(NULL," "));
134         if(type1) num1=num1*2+1;
135         else num1=num1*2;
136         if(type2) num2=num2*2-1;
137         else num2=num2*2;
138         switch(jud[0])
139         {
140         case 'U':
141             if(num1<=num2) 
142               insert(num1,num2,1);
143             break;
144         case 'I':
145             if(num1<=num2)
146             {
147                 if(0<=num1-1) clear(0,num1-1,1);
148                 if(num2+1<=65540*2) clear(num2+1,65540*2,1);
149             }
150             else clear(0,65540*2,1);
151             break;
152         case 'D':
153             if(num1<=num2)
154               clear(num1,num2,1);
155             break;
156         case 'C':
157             if(num1<=num2)
158             {
159             if(0<=num1-1) clear(0,num1-1,1);
160             if(num2+1<=65540*2) clear(num2+1,65540*2,1);
161             turn(num1,num2,1);
162             }
163             else
164                 clear(0,65540*2,1);
165             break;
166         case 'S':
167             if(num1<=num2)
168                 turn(num1,num2,1);
169             break;
170         }
171     }
172     print();
173     return 0;
174 }

posted on 2011-09-09 09:31 yzhw 閱讀(670) 評論(0)  編輯 收藏 引用 所屬分類: data struct

<2010年12月>
2829301234
567891011
12131415161718
19202122232425
2627282930311
2345678

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久久久久久久久免费看 | 欧美一区二区免费观在线| 黄色av日韩| 国产综合在线视频| 国产精品一区二区久久国产| 国产日韩精品久久| 国产一区二区三区精品久久久| 国产欧美日韩视频一区二区| 国产一区二区三区四区在线观看| 精品成人国产| 91久久中文| 亚洲免费视频网站| 久久久国产精品一区二区三区| 久久久久久国产精品mv| 欧美国产91| 99热这里只有精品8| 亚洲性人人天天夜夜摸| 久久九九精品| 欧美人与性动交cc0o| 国产精品国产三级国产普通话蜜臀 | 黑人极品videos精品欧美裸| 在线国产精品一区| 亚洲一区成人| 榴莲视频成人在线观看| 亚洲精品视频免费在线观看| 性感少妇一区| 欧美精品一区二区三区视频 | 日韩亚洲精品电影| 久久精品亚洲一区二区| 亚洲精品国产无天堂网2021| 亚洲精品1区| 欧美亚洲综合在线| 欧美日韩亚洲一区二区三区在线 | 欧美在线不卡| 亚洲国产精品成人精品| 欧美激情女人20p| 美女视频一区免费观看| 亚洲人体影院| 久久精品在线观看| 久久精品91久久久久久再现| 欧美日韩精品福利| 激情欧美丁香| 性感少妇一区| 9人人澡人人爽人人精品| 久久中文欧美| 国产丝袜美腿一区二区三区| 亚洲一区二区三区免费观看| 免费在线成人| 久久久久国产精品一区二区| 国产精品久久久久一区二区| 夜夜爽av福利精品导航| 麻豆国产va免费精品高清在线| 在线视频精品一区| 欧美激情1区2区3区| 亚洲电影av在线| 久久九九有精品国产23| 中文久久乱码一区二区| 欧美日韩免费高清| 日韩亚洲视频| 亚洲黑丝在线| 欧美精品色网| 夜色激情一区二区| 亚洲国产女人aaa毛片在线| 久久一区二区三区四区五区| 韩国v欧美v日本v亚洲v| 久久精品日产第一区二区| 小辣椒精品导航| 国产一区二区三区四区三区四 | 欧美精品v日韩精品v国产精品| 亚洲电影观看| 欧美成人日韩| 欧美激情91| 夜夜嗨av一区二区三区网站四季av| 亚洲国产精品久久| 欧美日韩成人在线视频| 一区二区高清在线观看| 亚洲毛片在线| 国产美女一区二区| 久久久久中文| 免费影视亚洲| 亚洲香蕉网站| 午夜精品一区二区三区在线播放 | 亚洲欧美自拍偷拍| 亚洲欧美另类国产| 国产一区二区电影在线观看 | 欧美本精品男人aⅴ天堂| 久久久久久999| 亚洲视频免费在线观看| 国产精品永久免费| 亚洲精品社区| 亚洲国产精品国自产拍av秋霞| 性视频1819p久久| 国产午夜精品一区二区三区欧美| 欧美在线影院| 欧美1区2区3区| 亚洲欧洲99久久| 另类激情亚洲| 香蕉成人久久| 久久综合久久综合这里只有精品| 亚洲精品影视| 亚洲欧美国产毛片在线| 好吊色欧美一区二区三区视频| 91久久在线播放| 国产午夜精品视频| 亚洲精品老司机| 亚洲电影观看| 亚洲欧洲av一区二区| 亚洲精品乱码久久久久久蜜桃麻豆 | 亚洲国产欧美一区二区三区久久 | 一区二区三区高清在线观看| 亚洲网站视频福利| 合欧美一区二区三区| 亚洲一二区在线| 最新国产精品拍自在线播放| 亚洲欧美一区二区精品久久久| 91久久夜色精品国产网站| 亚洲一区在线观看免费观看电影高清| 狠狠色狠狠色综合人人| 99re这里只有精品6| 亚洲国产视频a| 久久精品理论片| 亚洲欧美日本国产专区一区| 欧美精品乱码久久久久久按摩| 久久久91精品国产一区二区精品| 欧美日韩国产区一| 亚洲国产欧美一区| 亚洲国产精品一区二区第四页av | 亚洲黄色成人久久久| 欧美一区二区三区日韩| 亚洲少妇最新在线视频| 欧美韩日一区| 亚洲第一视频网站| 欧美精品一区二区三区在线看午夜| 亚洲欧美日韩系列| 亚洲视频香蕉人妖| 欧美成人福利视频| 欧美激情视频一区二区三区不卡| 国产亚洲欧美一级| 亚洲欧美日韩高清| 欧美一区二区免费视频| 欧美性事免费在线观看| 亚洲精品一区二区三区四区高清| 亚洲精品久久久久久久久久久久久| 久久―日本道色综合久久| 美女网站在线免费欧美精品| 亚洲激情黄色| 欧美精品粉嫩高潮一区二区| 欧美激情一区二区三区成人| 亚洲人永久免费| 欧美激情综合色| 亚洲卡通欧美制服中文| 日韩视频不卡| 欧美三级乱码| 午夜精品久久久久久| 久久精品在线免费观看| 国产日韩综合一区二区性色av| 欧美一站二站| 欧美sm重口味系列视频在线观看| 亚洲大片免费看| 欧美激情亚洲另类| 99精品视频免费| 久久国产精品久久久久久电车| 国户精品久久久久久久久久久不卡| 久久久夜精品| 亚洲精品国产精品乱码不99按摩| 亚洲一线二线三线久久久| 国产一区二区三区成人欧美日韩在线观看 | 亚洲精品1区2区| 久久婷婷国产综合国色天香| 免费在线观看日韩欧美| 亚洲免费电影在线| 国产亚洲成年网址在线观看| 老司机午夜精品| 一本大道久久a久久综合婷婷| 久久国产精品久久精品国产 | 国产精品系列在线播放| 久久大综合网| 亚洲免费电影在线观看| 久久精品一区中文字幕| 日韩一级裸体免费视频| 国产精品久久一区二区三区| 久久青青草原一区二区| 日韩一区二区福利| 久久综合伊人77777尤物| 99视频在线精品国自产拍免费观看| 国产精品影片在线观看| 欧美精品偷拍| 久久综合久久久| 欧美亚洲免费| 亚洲精品一区久久久久久| 久久久久国色av免费看影院| 中文精品99久久国产香蕉| 尤物99国产成人精品视频| 国产精品成人在线观看| 欧美亚洲专区| 亚洲激情视频在线播放| 欧美日韩另类在线| 免费不卡在线观看| 性xx色xx综合久久久xx| 亚洲视频一区在线|