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

C++分析研究  
C++
日歷
<2013年9月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345
統計
  • 隨筆 - 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 閱讀(411) 評論(0)  編輯 收藏 引用
 
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>
            亚洲青涩在线| 亚洲综合视频一区| 免费不卡在线视频| 亚洲视频狠狠| 能在线观看的日韩av| 亚洲日本精品国产第一区| 精品不卡一区二区三区| 欧美成人国产一区二区| 亚洲桃花岛网站| 91久久精品一区二区别| 性欧美精品高清| 亚洲精品你懂的| 亚洲国产欧美一区二区三区同亚洲| 欧美日韩国产首页在线观看| 亚洲一区二区三区乱码aⅴ| 欧美在线视频日韩| 亚洲欧洲午夜| 99精品欧美| 久久久夜夜夜| 免费精品99久久国产综合精品| 可以免费看不卡的av网站| 性欧美video另类hd性玩具| 亚洲免费人成在线视频观看| 亚洲国产精品视频| 亚洲午夜精品网| 老司机精品福利视频| 国产精品高潮在线| 亚洲毛片av在线| 麻豆9191精品国产| 亚洲午夜黄色| 欧美日韩国产精品| 伊人成年综合电影网| 午夜精品视频在线| 99国产一区| 欧美成人激情在线| 精品白丝av| 欧美一区二区三区视频在线 | 尤物网精品视频| 一区二区三区日韩欧美| 麻豆国产精品va在线观看不卡| 一本一本久久| 欧美gay视频| 激情久久五月天| 久久成人羞羞网站| 亚洲一区欧美激情| 国产精品久久网| 亚洲午夜在线观看| 亚洲黄色免费网站| 久久综合色一综合色88| 国产嫩草一区二区三区在线观看 | 亚洲美女精品久久| 欧美不卡视频一区| 亚洲黄色在线看| 免费日韩精品中文字幕视频在线| 午夜精品久久久久久久男人的天堂 | 久久久久国产精品www| 亚洲在线播放| 国产精品一区亚洲| 中文欧美字幕免费| 国产精品一区亚洲| 蜜桃伊人久久| 欧美激情1区2区| 日韩天天综合| 亚洲美女区一区| 欧美天堂亚洲电影院在线观看| 亚洲乱码国产乱码精品精| 亚洲第一二三四五区| 亚洲特级片在线| 蜜桃久久精品乱码一区二区| 亚洲欧美亚洲| 国产亚洲第一区| 久久久久欧美| 噜噜噜在线观看免费视频日韩| 亚洲黄色成人| 亚洲精品孕妇| 国产精品乱码人人做人人爱 | 亚洲私人影院| 夜夜爽99久久国产综合精品女不卡 | 久久久久9999亚洲精品| 久久久久久亚洲综合影院红桃 | 亚洲欧美激情诱惑| 国产视频欧美视频| 欧美成年人网站| 欧美日韩三区| 久久黄色影院| 欧美猛交免费看| 亚洲欧美怡红院| 欧美专区一区二区三区| 亚洲激情视频网站| 在线亚洲精品| 亚洲成人中文| 亚洲无线一线二线三线区别av| 国产一区二区三区免费不卡| 欧美国产精品v| 国产精品久久久久久模特| 久久久久五月天| 欧美日韩福利| 另类综合日韩欧美亚洲| 欧美日韩精品系列| 久久这里有精品视频| 欧美视频三区在线播放| 国产精品久久久久久五月尺| 一区二区成人精品 | 久久精品久久综合| 亚洲欧美日韩天堂| 国产精品女主播| 午夜精品久久久久| 国产亚洲福利一区| 亚洲韩国日本中文字幕| 国产精品乱码| 亚洲精品国产精品国自产在线 | 校园春色综合网| 中日韩视频在线观看| 久久久久久久久综合| 午夜精品久久久久久久蜜桃app| 免费欧美日韩| 久久综合激情| 国产欧美日韩精品在线| av成人老司机| 一本色道久久综合亚洲精品不| 久热re这里精品视频在线6| 欧美在线一二三| 国产精品久久久久9999| 日韩天堂av| 亚洲视频第一页| 欧美日韩三级一区二区| 亚洲精品男同| 999在线观看精品免费不卡网站| 久久久久国产精品www| 久久久久久亚洲精品杨幂换脸| 国产精品日韩专区| 亚洲欧美日韩国产中文| 午夜影视日本亚洲欧洲精品| 国产精品激情| 亚洲欧美一区二区三区极速播放 | 亚洲欧美一区二区在线观看| 欧美视频一区二| aa日韩免费精品视频一| 亚洲图色在线| 国产精品一区一区三区| 午夜精品婷婷| 玖玖精品视频| 91久久国产综合久久91精品网站| 久久先锋影音| 欧美黄色大片网站| 亚洲免费大片| 国产精品久久久久久久久久免费看 | 亚洲一区二区三区午夜| 亚洲欧美日韩一区二区三区在线观看| 欧美日韩免费网站| 一区二区久久久久| 亚洲私人黄色宅男| 国产农村妇女毛片精品久久麻豆| 另类综合日韩欧美亚洲| 欧美一级大片在线免费观看| 国产日产欧美精品| 久久精品二区亚洲w码| 国产精品日韩高清| 欧美亚洲一级片| 美女视频黄免费的久久| 亚洲精品视频免费在线观看| 欧美三级欧美一级| 午夜欧美视频| 亚洲第一页中文字幕| 一区二区日韩欧美| 国产日本欧美一区二区| 狂野欧美一区| 亚洲午夜伦理| 欧美福利电影在线观看| 亚洲一级影院| 一区二区三区自拍| 欧美日韩一区二区国产| 久久国产88| 一区二区久久久久| 欧美顶级艳妇交换群宴| 午夜日韩电影| 在线视频日韩| 亚洲国产精品ⅴa在线观看| 国产精品第三页| 欧美ab在线视频| 欧美一二三区在线观看| 亚洲精品一线二线三线无人区| 久久久精品国产免大香伊| 夜夜狂射影院欧美极品| 在线不卡视频| 国产日韩欧美综合精品| 欧美精品久久久久久久| 久久精品午夜| 亚洲男人第一av网站| 亚洲精品国产品国语在线app| 久久久噜噜噜久噜久久| 亚洲欧美综合精品久久成人| 亚洲另类视频| 亚洲国产美女精品久久久久∴| 国产精品久久久久久久9999| 欧美精品一区二区三| 麻豆精品视频| 久久一区激情| 久久亚洲综合色| 久久精品人人|