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

C++分析研究  
C++
日歷
<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910
統計
  • 隨筆 - 92
  • 文章 - 4
  • 評論 - 4
  • 引用 - 0

導航

常用鏈接

留言簿

隨筆檔案

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

 

  題意:區間交、并、減、補

  思路:用線段樹的葉子節點記錄該點是否被區間覆蓋,因為有開區間的情況,因此考慮離散,將數值乘以2。

  U:把區間[l,r]覆蓋成1

  I:把[-∞,l)(r,∞]覆蓋成0

  D:把區間[l,r]覆蓋成0

  C:把[-∞,l)(r,∞]覆蓋成0 , 且[l,r]區間0/1互換

  S:[l,r]區間0/1互換

  區間修改容易做,但是加上區間異或就難了。

  我們考慮維護這樣一棵線段樹,如果區段的setv不是-1(初始化時候為-1),則說明該節點所對應的區段內全部的值為setv,如果根節點和子節點的setv值都不為-1,我們只認根節點上面的setv值。然后維護一個xorv值,表示該節點對應區段是否被異或奇數次(異或偶數次和沒異或一樣,是0)。這個xorv值一定出現在查找時第一次遇到setv值的前面,也就是說,查找時會先遇到有意義的xorv值,再遇到有意義的setv值(有意義是指,xorv=1,或者setv!=-1)。當要修改某個區段或尋找某個區段的過程中,xorv值和setv值會用pushdown不斷往下壓。明顯我們可以知道這個性質:當一個區間被覆蓋后,不管之前有沒有異或標記都沒有意義了。所以當一個節點得到覆蓋標記時把異或標記清空托福答案

  而當一個節點得到異或標記的時候,先判斷覆蓋標記,如果是0或1,直接改變一下覆蓋標記,不然的話改變異或標記托福改分

  輸出的時候,我們可以用一個hash數組記錄,用一個query將線段樹上的值往下壓到hash數組里面。

  注意幾個問題:1.出現0的情況

  2.(3,3)這種空集的情況

  #include<cstdio>

  #include<cstring>

  #define M ((L+R)>>1)

  #define ls (o<<1)

  #define rs (o<<1|1)

  #define lson ls,L,M

  #define rson rs,M+1,R

  const int maxn=66666*2;

  bool hash[maxn],empty=1,flag=0;

  int n,yl,yr,v,setv[maxn*4],xorv[maxn*4],a,b,low=0,high;

  char op,left,right;

  void fxor(int o) {if(setv[o]>=0) setv[o]^=1; else xorv[o]^=1;}

  void pushdown(int o)

  {

  if(setv[o]>=0) {setv[ls]=setv[rs]=setv[o];xorv[ls]=xorv[rs]=0;setv[o]=-1;}

  if(xorv[o])

  {

  fxor(ls);

  fxor(rs);

  xorv[o]=0;

  }

  }

  void setupdate(int o,int L,int R)

  {

  if(yl<=L && R<=yr) {xorv[o]=0;setv[o]=v;return;}

  pushdown(o);

  if(yl<=M) setupdate(lson);

  if(M<yr) setupdate(rson);

  }

  void xorupdate(int o,int L,int R)

  {

  if(yl<=L && R<=yr){fxor(o);return;}

  pushdown(o);

  if(yl<=M) xorupdate(lson);

  if(M<yr) xorupdate(rson);

  }

  void query(int o,int L,int R)

  {

  if(setv[o]>=0)

  {

  if(setv[o]) for(int i=L;i<=R;++i) hash[i]=1;//將信息壓倒hash里面去

  return;

  }

  pushdown(o);

  if(yl<=M) query(lson);

  if(M<yr) query(rson);

  }

  void init()

  {

  memset(setv,-1,sizeof(setv));

  memset(hash,0,sizeof(hash));

  xorv[1]=setv[1]=0;

  }

  void read()

  {

  while(~scanf("%c %c%d,%d%c ",&op,&left,&a,&b,&right))

  {

  a=(a+1)*2,b=(b+1)*2;

  if(left=='(') ++a; if(right==')') --b;

  if(op=='U')

  {

  v=1,yl=a,yr=b;

  if(yl<=yr) setupdate(1,1,maxn-1);

  }

  else if(op=='I')

  {

  v=0,yl=1,yr=a-1;

  if(yl<=yr) setupdate(1,1,maxn-1);

  yl=b+1,yr=maxn-1;

  if(yl<=yr) setupdate(1,1,maxn-1);

  }

  else if(op=='D')

  {

  v=0,yl=a,yr=b;

  if(yl<=yr) setupdate(1,1,maxn-1);

  }

  else if(op=='C')

  {

  v=0,yl=1,yr=a-1;

  if(yl<=yr) setupdate(1,1,maxn-1);

  yl=b+1,yr=maxn-1;

  if(yl<=yr) setupdate(1,1,maxn-1);

  yl=a,yr=b;

  if(yl<=yr) xorupdate(1,1,maxn-1);

  }

  else if(op=='S')

  {

  yl=a,yr=b;

  if(yl<=yr) xorupdate(1,1,maxn-1);

  }

  }

  }

  void print()

  {

  yl=1,yr=maxn-1;

  query(1,1,maxn-1);

  while(low<maxn)

  {

  while(!hash[low] && low<maxn) ++low;

  high=low+1;

  while(hash[high] && high<maxn) ++high;

  --high;

  if(low>=maxn) break;

  empty=0;

  if(flag) printf(" ");

  flag=1;

  if(low&1) printf("(");

  else printf("[");

  printf("%d,%d",(low/2)-1,(high-1)/2);

  if(high&1) printf(")");

  else printf("]");

  low=high+1;

  }

  if(empty) printf("empty set");

  puts("");

  }

  int main()

  {

  init();

  read();

  print();

  return 0;

  }

 

posted on 2013-09-03 00:21 HAOSOLA 閱讀(418) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


 
Copyright © HAOSOLA Powered by: 博客園 模板提供:滬江博客
PK10開獎 PK10開獎
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久福利电影| 欧美一区2区视频在线观看| 猛男gaygay欧美视频| 国产一区二区激情| 奶水喷射视频一区| 欧美电影免费观看| 亚洲桃色在线一区| 在线视频亚洲| 国产精品乱码人人做人人爱| 亚洲欧美日韩人成在线播放| 午夜精品理论片| 一区在线播放视频| 亚洲日本欧美天堂| 国产精品一区久久久| 久久综合福利| 欧美日韩91| 久久精品午夜| 欧美成人午夜激情在线| 亚洲一区二区精品在线| 欧美一区二区三区四区高清| 亚洲第一中文字幕| 99精品热视频只有精品10| 国产精品丝袜久久久久久app| 久久亚洲精品伦理| 欧美日韩在线视频观看| 久久国产99| 欧美岛国激情| 久久精品一区二区| 欧美—级在线免费片| 欧美在线亚洲| 欧美精品综合| 免费在线观看成人av| 欧美视频一二三区| 亚洲福利视频一区| 国产日韩综合| 99视频超级精品| 曰韩精品一区二区| 亚洲自拍都市欧美小说| 亚洲精品久久视频| 久久精品久久综合| 亚洲小说欧美另类社区| 欧美成人69av| 农村妇女精品| 韩国三级电影一区二区| 艳女tv在线观看国产一区| 亚洲国产精品久久久久婷婷884| 亚洲一线二线三线久久久| 亚洲精品一二三区| 久久综合图片| 久久人91精品久久久久久不卡| 欧美日本亚洲韩国国产| 欧美国产精品专区| 一区在线免费| 欧美在线观看视频在线| 亚洲欧美日韩精品| 欧美午夜免费电影| 亚洲精品欧美| 亚洲电影在线观看| 久久久久成人精品免费播放动漫| 亚洲一区二区久久| 欧美日韩一区二区在线观看视频 | 尤物在线观看一区| 亚洲欧美日韩系列| 午夜伦理片一区| 国产精品国产馆在线真实露脸 | 午夜精品美女自拍福到在线| 欧美顶级少妇做爰| 欧美国产先锋| 亚洲精品女av网站| 欧美精品观看| 9人人澡人人爽人人精品| 在线亚洲高清视频| 欧美小视频在线| 亚洲一级影院| 久久精品成人| 国产在线观看精品一区二区三区 | 亚洲欧美日本视频在线观看| 亚洲免费一区二区| 国产欧美一区二区白浆黑人| 羞羞答答国产精品www一本| 欧美影院在线播放| 国产综合18久久久久久| 久久国产精品久久久久久久久久 | 午夜精品免费视频| 国产欧美一区二区三区在线老狼| 亚洲欧美日本伦理| 欧美福利视频一区| 一区二区精品在线| 国产欧美视频一区二区三区| 久久国产免费| 亚洲欧洲一区二区在线播放| 一区二区国产日产| 国产午夜精品理论片a级大结局| 性欧美办公室18xxxxhd| 亚洲第一在线视频| 亚洲欧美国产va在线影院| 国产亚洲午夜| 欧美国产精品| 亚洲欧美一区二区激情| 欧美国产免费| 午夜宅男欧美| 亚洲人久久久| 国产亚洲精品v| 欧美肥婆在线| 午夜亚洲性色福利视频| 欧美黄色成人网| 午夜国产精品影院在线观看| 亚洲第一偷拍| 国产女主播一区二区三区| 欧美成人激情在线| 欧美专区在线观看一区| 亚洲精品视频二区| 久久在线视频在线| 亚洲欧美在线一区| 日韩一级黄色大片| 一区二区在线观看视频| 国产精品免费小视频| 欧美国产精品va在线观看| 久久成人亚洲| 国产精品99久久久久久久久| 欧美成人蜜桃| 久久久综合香蕉尹人综合网| 亚洲欧美日韩视频二区| 99www免费人成精品| 伊人激情综合| 国产视频不卡| 国产精品欧美一区喷水| 欧美日韩www| 欧美国产欧美亚洲国产日韩mv天天看完整 | 日韩视频在线观看免费| 免费美女久久99| 欧美一区二区三区免费观看| 99视频热这里只有精品免费| 激情校园亚洲| 精品av久久久久电影| 国产一区二区三区无遮挡| 国产精品白丝av嫩草影院| 欧美片第1页综合| 欧美国产第二页| 欧美福利在线| 欧美了一区在线观看| 欧美激情国产精品| 欧美国产日韩一二三区| 久久亚洲国产精品日日av夜夜| 欧美一级视频精品观看| 性色av一区二区三区红粉影视| 在线亚洲欧美| 亚洲一区二区三区777| 亚洲在线视频网站| 亚洲免费网址| 亚欧成人精品| 久久久久se| 久久亚洲私人国产精品va| 老鸭窝亚洲一区二区三区| 免费亚洲婷婷| 欧美精品在线播放| 欧美日韩美女在线观看| 国产精品久久77777| 国产精品久久久久久久久久久久| 欧美视频福利| 国产欧美一区二区白浆黑人| 好吊妞这里只有精品| 国产综合色产| 亚洲国产专区校园欧美| 99re66热这里只有精品3直播| 99riav久久精品riav| 亚洲欧美精品在线观看| 久久成人免费视频| 免费成人毛片| 一本久道久久综合中文字幕| 亚洲一区二区三区在线| 久久免费99精品久久久久久| 欧美日韩不卡合集视频| 国产乱码精品1区2区3区| 亚洲第一区色| 亚洲欧美国产日韩中文字幕| 久久免费视频网| 亚洲精品中文字幕女同| 性高湖久久久久久久久| 欧美激情第一页xxx| 国产日韩欧美在线一区| 亚洲精品久久7777| 欧美一区二区三区男人的天堂 | 日韩小视频在线观看| 午夜视频一区二区| 欧美a级大片| 国产日韩欧美精品一区| 亚洲精品在线免费| 久久久精品日韩| 99国产成+人+综合+亚洲欧美| 欧美一区二区三区在线看 | 另类国产ts人妖高潮视频| 欧美午夜精品久久久久免费视| 黄色亚洲网站| 午夜精品电影| 亚洲欧洲视频在线| 久热精品在线视频| 国内精品国产成人| 亚洲欧美日韩精品久久久久| 亚洲成人中文|