• <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>
            隨筆 - 87  文章 - 279  trackbacks - 0
            <2025年7月>
            293012345
            6789101112
            13141516171819
            20212223242526
            272829303112
            3456789

            潛心看書研究!

            常用鏈接

            留言簿(19)

            隨筆分類(81)

            文章分類(89)

            相冊

            ACM OJ

            My friends

            搜索

            •  

            積分與排名

            • 積分 - 217972
            • 排名 - 117

            最新評論

            閱讀排行榜

            評論排行榜

            The k-th Largest Group
            Time Limit:2000MS? Memory Limit:131072K
            Total Submit:1222 Accepted:290

            Description

            Newman likes playing with cats. He possesses lots of cats in his home. Because the number of cats is really huge, Newman wants to group some of the cats. To do that, he first offers a number to each of the cat (1, 2, 3, …, n). Then he occasionally combines the group cat i is in and the group cat j is in, thus creating a new group. On top of that, Newman wants to know the size of the k-th biggest group at any time. So, being a friend of Newman, can you help him?

            Input

            1st line: Two numbers N and M (1 ≤ N, M ≤ 200,000), namely the number of cats and the number of operations.

            2nd to (m + 1)-th line: In each line, there is number C specifying the kind of operation Newman wants to do. If C = 0, then there are two numbers i and j (1 ≤ i, jn) following indicating Newman wants to combine the group containing the two cats (in case these two cats are in the same group, just do nothing); If C = 1, then there is only one number k (1 ≤ k ≤ the current number of groups) following indicating Newman wants to know the size of the k-th largest group.

            Output

            For every operation “1” in the input, output one number per line, specifying the size of the kth largest group.

            Sample Input

            10 10
            0 1 2
            1 4
            0 3 4
            1 2
            0 5 6
            1 1
            0 7 8
            1 1
            0 9 10
            1 1

            Sample Output

            1
            2
            2
            2
            2

            Hint

            When there are three numbers 2 and 2 and 1, the 2nd largest number is 2 and the 3rd largest number is 1.

            Source
            POJ Monthly--2006.08.27, zcgzcgzcg

            #include? < iostream >
            using ? namespace ?std;
            const ? int ?MAXN? = ? 200001 ;

            class ?UFset
            {
            public :
            ????
            int ?parent[MAXN];
            ????UFset();
            ????
            int ?Find( int );
            ????
            void ?Union( int ,? int );
            }
            ;

            UFset::UFset()
            {
            ????memset(parent,?
            - 1 ,? sizeof (parent));
            }


            int ?UFset::Find( int ?x)
            {
            ????
            if ?(parent[x]? < ? 0 )
            ????????
            return ?x;
            ????
            else
            ????
            {
            ????????parent[x]?
            = ?Find(parent[x]);
            ????????
            return ?parent[x];
            ????}
            // ?壓縮路徑
            }


            void ?UFset::Union( int ?x,? int ?y)
            {
            ????
            int ?pX? = ?Find(x);
            ????
            int ?pY? = ?Find(y);
            ????
            int ?tmp;
            ????
            if ?(pX? != ?pY)
            ????
            {
            ????????tmp?
            = ?parent[pX]? + ?parent[pY];? // ?加權合并
            ???????? if ?(parent[pX]? > ?parent[pY])
            ????????
            {
            ????????????parent[pX]?
            = ?pY;
            ????????????parent[pY]?
            = ?tmp;
            ????????}

            ????????
            else
            ????????
            {
            ????????????parent[pY]?
            = ?pX;
            ????????????parent[pX]?
            = ?tmp;
            ????????}

            ????}

            }


            int ?f[(MAXN + 1 ) * 3 ]? = ? { 0 } ;
            int ?n,?m;

            void ?initTree()
            {
            ????
            int ?l? = ? 1 ,?r? = ?n;
            ????
            int ?c? = ? 1 ;
            ????
            while ?(l? < ?r)
            ????
            {
            ????????f[c]?
            = ?n;
            ????????c?
            = ?c? * ? 2 ;
            ????????r?
            = ?(l? + ?r)? / ? 2 ;
            ????}

            ????f[c]?
            = ?n; // 葉子初始化
            }


            void ?insertTree( int ?k)
            {
            ????
            int ?l? = ? 1 ,?r? = ?n;
            ????
            int ?c? = ? 1 ;
            ????
            int ?mid;

            ????
            while ?(l? < ?r)
            ????
            {
            ????????f[c]
            ++ ;
            ????????mid?
            = ?(r? + ?l)? / ? 2 ;
            ????????
            if ?(k? > ?mid)
            ????????
            {
            ????????????l?
            = ?mid? + ? 1 ;
            ????????????c?
            = ?c? * ? 2 ? + ? 1 ;
            ????????}

            ????????
            else
            ????????
            {
            ????????????r?
            = ?mid;
            ????????????c?
            = ?c? * ? 2 ;
            ????????}

            ????}

            ????f[c]
            ++ ; // 葉子增加1
            }


            void ?delTree( int ?k)
            {
            ????
            int ?l? = ? 1 ,?r? = ?n;
            ????
            int ?c? = ? 1 ;
            ????
            int ?mid;

            ????
            while ?(l? < ?r)
            ????
            {
            ????????f[c]
            -- ;
            ????????mid?
            = ?(r? + ?l)? / ? 2 ;
            ????????
            if ?(k? > ?mid)
            ????????
            {
            ????????????l?
            = ?mid? + ? 1 ;
            ????????????c?
            = ?c? * ? 2 ? + ? 1 ;
            ????????}

            ????????
            else
            ????????
            {
            ????????????r?
            = ?mid;
            ????????????c?
            = ?c? * ? 2 ;
            ????????}

            ????}

            ????f[c]
            -- ; // 葉子減少1
            }


            int ?searchTree( int ?k)
            {
            ????
            int ?l? = ? 1 ,?r? = ?n;
            ????
            int ?c? = ? 1 ;
            ????
            int ?mid;

            ????
            while ?(l? < ?r)
            ????
            {
            ????????mid?
            = ?(l? + ?r)? / ? 2 ;
            ????????
            if ?(k? <= ?f[ 2 * c + 1 ])
            ????????
            {
            ????????????l?
            = ?mid? + ? 1 ;
            ????????????c?
            = ?c? * ? 2 ? + ? 1 ;
            ????????}

            ????????
            else
            ????????
            {
            ????????????k?
            -= ?f[ 2 * c + 1 ];
            ????????????r?
            = ?mid;
            ????????????c?
            = ?c? * ? 2 ;
            ????????}

            ????}

            ????
            return ?l;
            }


            int ?main()
            {
            ????
            int ?i,?j;
            ????
            int ?x,?y;
            ????
            int ?k;
            ????
            int ?l,?r;
            ????
            int ?cmd;
            ????
            int ?px,?py;
            ????
            int ?tx,?ty,?tz;
            ????UFset?UFS;

            ????
            ????scanf(
            " %d%d " ,? & n,? & m);
            ????initTree();
            ????
            for ?(i = 0 ;?i < m;?i ++ )
            ????
            {
            ????????scanf(
            " %d " ,? & cmd);
            ????????
            if ?(cmd? == ? 0 )
            ????????
            {
            ????????????scanf(
            " %d%d " ,? & x,? & y);
            ????????????px?
            = ?UFS.Find(x);
            ????????????py?
            = ?UFS.Find(y);
            ????????????
            if ?(px? != ?py)
            ????????????
            {
            ????????????????tx?
            = ? - UFS.parent[px];
            ????????????????ty?
            = ? - UFS.parent[py];
            ????????????????tz?
            = ?tx? + ?ty;
            ????????????????UFS.Union(x,?y);
            ????????????????insertTree(tz);
            ????????????????delTree(tx);
            ????????????????delTree(ty);
            ????????????}

            ????????}

            ????????
            else
            ????????
            {
            ????????????scanf(
            " %d " ,? & k);
            ????????????printf(
            " %d\n " ,?searchTree(k));
            ????????}

            ????}

            ????
            return ? 0 ;
            }
            posted on 2006-09-06 13:28 閱讀(816) 評論(4)  編輯 收藏 引用 所屬分類: ACM題目

            FeedBack:
            # re: pku2985 第一次用兩種數據結構解題, 并查集+線段樹 2006-09-22 13:24 A3
            可否講解一下線段樹部分  回復  更多評論
              
            # re: pku2985 第一次用兩種數據結構解題, 并查集+線段樹 2006-09-22 17:47 
            把區間劃出來, 節點(非葉子), 表示該區間里面含有多少個元素。
            如果 n = 10;
            而集合大小分別是 1, 1, 2, 6;

            則 區間(1-10) = 4; 區間(1-5) = 3;

            就這樣用線段樹動態維護每次集合合并后的集合大小。

            初始化(1-10) = 10;
            因為開始時, 集合大小為1, 1, 1, 1, 1, 1, 1, 1, 1, 1  回復  更多評論
              
            # re: pku2985 第一次用兩種數據結構解題, 并查集+線段樹 2006-09-24 19:53 Optimistic
            偶的第一次呢 靜待。。。  回復  更多評論
              
            # re: pku2985 第一次用兩種數據結構解題, 并查集+線段樹 2006-09-24 22:23 
            +U ^_^  回復  更多評論
              
            亚洲AV无码久久精品蜜桃| 久久夜色精品国产噜噜亚洲AV| 久久久噜噜噜www成人网| 人妻精品久久无码区| 久久婷婷久久一区二区三区| 久久综合丁香激情久久| 久久久精品日本一区二区三区 | 久久伊人精品青青草原高清| 久久综合九色综合久99| 久久婷婷色香五月综合激情| 国内精品久久久久久99| 国产亚州精品女人久久久久久| 久久精品国产男包| 日本免费一区二区久久人人澡| 久久夜色精品国产亚洲| 日本精品久久久久中文字幕8| 亚洲欧美国产日韩综合久久| 99久久人妻无码精品系列| 久久久高清免费视频| 青青青青久久精品国产| 久久久久久久女国产乱让韩| 人妻久久久一区二区三区| 无码8090精品久久一区| 狠狠色婷婷久久一区二区三区 | 久久精品国产亚洲AV无码麻豆| 一本一道久久精品综合| av无码久久久久久不卡网站| 久久综合九色综合网站| 天天影视色香欲综合久久| 国产伊人久久| 久久精品无码一区二区三区日韩 | 99久久亚洲综合精品网站| 亚洲欧洲日产国码无码久久99| 欧美激情精品久久久久久久九九九| 久久精品一区二区国产| av国内精品久久久久影院| 久久综合久久自在自线精品自| 中文精品久久久久人妻不卡| 亚洲国产精品无码久久久不卡| 亚洲精品国产美女久久久 | 久久精品综合一区二区三区|