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

A Za, A Za, Fighting...

堅信:勤能補拙

PKU 2777 Count Color

問題:
http://acm.pku.edu.cn/JudgeOnline/problem?id=2777

思路:
線段樹的典型題

參考:
http://blog.csdn.net/xiaofengsheng/archive/2009/03/03/3953265.aspx

代碼:
  1 #include<stdio.h>
  2 #include<stdlib.h>
  3 #include<string.h>
  4 #define MAX_N 100001
  5 #define MAX_T 31
  6 #define LEFT(i) (i<<1)
  7 #define RIGHT(i) ((i<<1)+1)
  8 int L, T, O;
  9 struct Node {
 10     int left, right;
 11     int color;
 12 };
 13 struct Node nodes[MAX_N*3];
 14 int rt, visited[MAX_T];
 15 
 16 void
 17 build(int begin, int end, int step)
 18 {
 19     int mid;
 20     nodes[step].left = begin;
 21     nodes[step].right = end;
 22     nodes[step].color = 1;
 23     if(begin == end)
 24         return;
 25     mid = (begin+end)>>1;
 26     build(begin, mid, LEFT(step));
 27     build(mid+1, end, RIGHT(step));
 28 }
 29 
 30 void
 31 insert(int begin, int end, int color, int step)
 32 {
 33     int mid;
 34     if(nodes[step].left==begin && nodes[step].right==end) {
 35         nodes[step].color = color;
 36         return;
 37     };
 38     if(nodes[step].color != -1) {
 39         nodes[LEFT(step)].color = nodes[RIGHT(step)].color = nodes[step].color;
 40         nodes[step].color = -1/* mixed color */
 41     }
 42     mid = (nodes[step].left+nodes[step].right)>>1;
 43     if(begin > mid) 
 44         insert(begin, end, color, RIGHT(step));
 45     else if(end<=mid)
 46         insert(begin, end, color, LEFT(step));
 47     else {
 48         insert(begin, mid, color, LEFT(step));
 49         insert(mid+1, end, color, RIGHT(step));
 50     }
 51 }
 52 
 53 void
 54 calculate(int begin, int end, int step)
 55 {
 56     if(nodes[step].color != -1) {
 57         if(!visited[nodes[step].color]) {
 58             visited[nodes[step].color] = 1;
 59             ++rt;
 60         }
 61         return;
 62     }
 63     int mid = (nodes[step].left+nodes[step].right)>>1;
 64     if(mid < begin)
 65         calculate(begin, end, RIGHT(step));
 66     else if(mid >= end)
 67         calculate(begin, end, LEFT(step));
 68     else {
 69         calculate(begin, mid, LEFT(step));
 70         calculate(mid+1, end, RIGHT(step));
 71     }
 72 }
 73 
 74 int
 75 main(int argc, char **argv)
 76 {
 77     int i, a, b, c;
 78     char ops[2];
 79     while(scanf("%d %d %d"&L, &T, &O) != EOF) {
 80         build(1, L, 1);
 81         for(i=1; i<=O; i++) {
 82             scanf("%s", ops);
 83             if(ops[0== 'C') {
 84                 scanf("%d %d %d"&a, &b, &c);
 85                 if(a <= b)
 86                     insert(a, b, c, 1);
 87                 else
 88                     insert(b, a, c, 1);
 89             } else if(ops[0== 'P') {
 90                 scanf("%d %d"&a, &b);
 91                 rt = 0;
 92                 memset(visited, 0sizeof(visited));
 93                 if(a <= b)
 94                     calculate(a, b, 1);
 95                 else
 96                     calculate(b, a, 1);
 97                 printf("%d\n", rt);
 98             }
 99         }
100     }
101 }

posted on 2010-09-16 10:57 simplyzhao 閱讀(270) 評論(0)  編輯 收藏 引用 所屬分類: E_數據結構

導航

<2010年11月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

統計

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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在线| 亚洲福利在线视频| 精品动漫3d一区二区三区免费版| 国产视频综合在线| 国产主播精品| 亚洲第一区在线观看| 一区二区三区在线视频播放| 精品粉嫩aⅴ一区二区三区四区| 黄色一区三区| 亚洲免费观看视频| 亚洲一区二区免费视频| 欧美一区二区三区免费观看视频| 久久久久久电影| 91久久中文| 一区二区三区高清在线| 欧美自拍偷拍午夜视频| 欧美韩国日本一区| 国产精品久久网站| 在线日韩欧美| 午夜电影亚洲| 欧美韩国在线| 亚洲欧美一区二区激情| 浪潮色综合久久天堂| 国产精品剧情在线亚洲| 永久免费视频成人| 亚洲亚洲精品在线观看 | 亚洲理伦电影| 午夜日韩在线| 亚洲高清视频中文字幕| 亚洲欧美日韩在线| 欧美大片免费久久精品三p| 国产精品一区二区三区免费观看| 红桃视频国产精品| 亚洲午夜精品久久| 亚洲第一精品夜夜躁人人爽| 亚洲午夜精品福利| 欧美大片免费看| 国模吧视频一区| 亚洲免费在线电影| 亚洲国产小视频| 久久夜色精品国产欧美乱极品| 中文av字幕一区| 久久视频在线视频| 国产精自产拍久久久久久| 99热免费精品| 免费视频一区二区三区在线观看| 亚洲性夜色噜噜噜7777| 欧美日韩国产色综合一二三四| 在线观看久久av| 久久米奇亚洲| 欧美亚洲三区| 国产视频丨精品|在线观看| 亚洲免费一级电影| 99精品欧美| 欧美成人亚洲成人| 亚洲国产天堂久久综合网| 久久国产精品99国产精| 亚洲欧美第一页| 国产精品男人爽免费视频1| 中文日韩在线| 日韩一级不卡| 欧美视频福利| 午夜欧美大片免费观看| 亚洲特级毛片| 国产欧美欧美| 久久久av网站| 久久亚洲精品网站| 亚洲精品视频啊美女在线直播| 蜜桃av噜噜一区| 老司机久久99久久精品播放免费 | 一区二区三区四区五区视频| 亚洲精品1区2区| 欧美日韩另类视频| 亚洲免费视频中文字幕| 亚洲欧美精品伊人久久| 国产欧亚日韩视频| 老司机午夜精品视频| 狂野欧美激情性xxxx| 99精品国产热久久91蜜凸| 99re视频这里只有精品| 国产精品美女www爽爽爽| 久久不射中文字幕| 久久久综合免费视频| 亚洲精品乱码视频 | 久久九九精品99国产精品| 伊人久久大香线蕉综合热线 | 亚洲午夜视频在线| 亚洲欧美日韩国产综合| 国一区二区在线观看| 亚洲国产高清视频| 国产精品视频久久久| 久久漫画官网| 欧美精品福利在线| 欧美在线观看视频| 久久这里只有| 亚洲国产精品电影| 欧美激情一区| 亚洲一区二区三区乱码aⅴ蜜桃女| 一区二区日韩| 极品av少妇一区二区| 亚洲三级性片| 精品动漫3d一区二区三区免费版| 91久久久久久久久| 国产午夜精品视频| 日韩午夜免费视频| 在线电影欧美日韩一区二区私密| 91久久国产综合久久| 国产在线高清精品| 99热免费精品在线观看| 影音先锋另类| 午夜在线成人av| 在线一区免费观看| 老司机精品福利视频| 欧美一区综合| 欧美极品一区二区三区| 久久尤物视频| 国产情人综合久久777777| 亚洲精品五月天| 亚洲国产一区在线| 久久久精品国产一区二区三区 | 在线日韩电影| 久久成人免费电影| 亚洲欧美日韩一区在线| 欧美精品午夜| 亚洲国产成人91精品| 狠狠综合久久| 欧美中文字幕在线播放| 午夜精品视频在线观看| 欧美视频一区二区| 亚洲精品在线观看免费| 亚洲伦伦在线| 欧美激情视频给我| 亚洲激情在线播放| 日韩视频免费看| 欧美肥婆在线| 亚洲人成久久| 国产精品99久久久久久久女警| 欧美黑人在线观看| 亚洲精品国产精品久久清纯直播 | 国产伦精品一区二区三区视频孕妇 | 麻豆精品在线观看| 欧美va天堂| 亚洲日本中文字幕| 欧美激情亚洲一区| 99re6热在线精品视频播放速度| 亚洲肉体裸体xxxx137| 欧美精品久久久久久久免费观看 | 久久三级福利| 国产视频久久| 欧美伊人久久久久久午夜久久久久| 欧美一区二区三区在线观看| 国产精品女同互慰在线看| 亚洲欧美视频一区二区三区| 欧美亚洲一级| 韩日在线一区| 欧美黄网免费在线观看| 亚洲毛片播放| 欧美影院成年免费版| 国产自产高清不卡| 欧美粗暴jizz性欧美20| 99国产精品久久久久久久成人热| 亚洲一区999| 狠狠色狠狠色综合日日tαg| 美日韩免费视频| 99精品免费网| 久久亚洲国产精品一区二区| 亚洲国产成人tv| 欧美日韩另类一区| 久久精品一区二区| 亚洲精品美女在线| 久久精品99无色码中文字幕| 亚洲激情网站| 国产欧美一区二区三区在线看蜜臀 | 奶水喷射视频一区| 在线性视频日韩欧美| 国产欧美韩日| 欧美韩国在线| 欧美制服丝袜第一页| 亚洲激情另类| 久久国产欧美精品| 99精品99| 精品成人一区二区三区| 欧美日韩一区二区三区四区在线观看| 亚洲女同精品视频| 最新国产精品拍自在线播放| 欧美中文字幕视频| 在线视频欧美日韩| 亚洲国产欧美日韩| 国产亚洲一级高清| 欧美视频一二三区| 欧美第一黄网免费网站| 久久九九国产| 午夜精品久久久久久久99水蜜桃 | 久久精品女人| 午夜精品久久久久久久99热浪潮| 亚洲人成网在线播放| 国产日韩欧美一二三区| 欧美性猛片xxxx免费看久爱| 欧美国产日本韩|