• <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>
            #include? < iostream >
            #include?
            < algorithm >

            using ? namespace ?std;

            #define ?N?10010

            struct ?Node{
            ????
            int ?x,?y;
            ????Node(?
            int ?a = ? 0 ,? int ?b = ? 0 ?):x(a),?y(b)?{}
            };

            int ??n,?idx[N * 2 ],?data[N * 2 ],?pos;
            Node?d[N];

            int ?bfind(? int ?v?){
            ????
            int ?left = ? 0 ,?right = ?n * ? 2 ;
            ????
            while (?left + ? 1 < ?right?){
            ????????
            int ?m = ?(left + ?right) >> ? 1 ;
            ????????
            if (?data[m] < ?v?)?left = ?m;
            ????????
            else ? if (?data[m] > ?v?)?right = ?m;
            ????????
            else ? return ?idx[m];
            ????}
            ????
            return ?idx[left];
            }

            int ?tb[N * 8 ],?flag[N];
            void ?insert(? int ?l,? int ?r,? int ?a,? int ?b,? int ?rt,? int ?c?){
            ????
            if (?l == ?a? && ?r == ?b?){
            ????????tb[rt]
            = ?c;? return ;?}
            ????
            int ?m = ?(l + ?r) >> ? 1 ;
            ????
            if (?tb[rt] > ? 0 ?){
            ????????tb[rt
            << 1 ] = ?tb[rt],?tb[(rt << 1 ) + 1 ] = ?tb[rt],?tb[rt] = ? 0 ;?}
            ????
            if (?b <= ?m?)?insert(?l,?m,?a,?b,?rt << ? 1 ,?c?);
            ????
            else ? if (?a > ?m?)?insert(?m + ? 1 ,?r,?a,?b,?(rt << 1 ) + ? 1 ,?c?);
            ????
            else {
            ????????insert(?l,?m,?a,?m,?rt
            << ? 1 ,?c?);
            ????????insert(?m
            + ? 1 ,?r,?m + ? 1 ,?b,?(rt << 1 ) + ? 1 ,?c?);?}
            }
            void ?calc(? int ?l,? int ?r,? int ?rt?){
            ????
            if (?tb[rt] > ? 0 ?)?{?flag[?tb[rt]?] = ? 1 ;? return ;?}
            ????
            else {
            ????????
            if (?l == ?r?)? return ;
            ????????
            int ?m = ?(l + ?r) >> ? 1 ;
            ????????calc(?l,?m,?rt
            << ? 1 ?);
            ????????calc(?m
            + ? 1 ,?r,?(rt << 1 ) + ? 1 ?);
            ????}
            }

            int ?main(){
            ????
            int ?test;
            ????scanf(
            " %d " , & test);
            ????
            while (?test -- ?){
            ????????scanf(
            " %d " , & n?);
            ????????
            int ?u,?v;
            ????????
            for (? int ?i = ? 0 ;?i < ?n;? ++ i?){
            ????????????scanf(
            " %d%d " , & u, & v?);
            ????????????d[i]
            = ?Node(?u,?v?);
            ????????????data[i
            << 1 ] = ?u,?data[(i << 1 ) + 1 ] = ?v;
            ????????}
            ????????sort(?data,?data
            + ?n * ? 2 ?);
            ????????pos
            = ? 1 ;?idx[ 0 ] = ? 1 ;
            ????????
            for (? int ?i = ? 1 ;?i < ?n * ? 2 ;? ++ i?)
            ????????
            if (?data[i] != ?data[i - 1 ]?)?idx[i] = ? ++ pos;
            ????????
            else ??idx[i] = ?pos;
            ????????
            ????????memset(?tb,?
            0 ,? sizeof (tb)?);?
            ????????memset(?flag,?
            0 ,? sizeof (flag)?);
            ????????
            for (? int ?i = ? 0 ;?i < ?n;? ++ i?){
            ????????????u
            = ?bfind(?d[i].x?),?v = ?bfind(?d[i].y?);
            ????????????insert(?
            1 ,?pos,?u,?v,? 1 ,?i + ? 1 ?);
            ????????}
            ????????calc(?
            1 ,?pos,? 1 ?);
            ????????
            int ?ans = ? 0 ;
            ????????
            for (? int ?i = ? 1 ;?i <= ?n;? ++ i?)
            ????????
            if (?flag[i]?)?ans ++ ;
            ????????printf(
            " %d\n " ,?ans?);
            ????}
            ????
            return ? 0 ;
            }
            posted on 2009-07-14 20:19 Darren 閱讀(368) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)
            国内精品久久久久影院亚洲| 久久无码一区二区三区少妇 | 综合网日日天干夜夜久久| 久久99国产精品尤物| 久久99久久99小草精品免视看| 久久婷婷色综合一区二区| 久久久久国产日韩精品网站 | 久久97久久97精品免视看秋霞| 色婷婷久久久SWAG精品| 日韩人妻无码一区二区三区久久| 久久噜噜电影你懂的| 久久久无码精品亚洲日韩京东传媒 | 久久久久久A亚洲欧洲AV冫| 久久午夜羞羞影院免费观看| 久久伊人中文无码| 99久久精品午夜一区二区| 久久婷婷午色综合夜啪| 国产精品九九久久精品女同亚洲欧美日韩综合区 | 欧美精品福利视频一区二区三区久久久精品 | 久久久久成人精品无码中文字幕 | 国产91色综合久久免费分享| 久久亚洲天堂| 亚洲狠狠久久综合一区77777| 三上悠亚久久精品| 久久精品国产影库免费看| 狠狠狠色丁香婷婷综合久久五月 | 久久精品中文字幕大胸| 97久久精品无码一区二区天美| 亚洲精品99久久久久中文字幕 | 久久久久综合中文字幕| 久久99精品国产一区二区三区| 伊人久久大香线蕉精品不卡| 狠狠综合久久综合中文88| 欧美一区二区三区久久综合| 久久久久久精品无码人妻| 亚洲性久久久影院| 久久精品国产欧美日韩99热| 热RE99久久精品国产66热| 久久夜色撩人精品国产| 久久精品99无色码中文字幕| 久久久久一本毛久久久|