• <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>

            The Sun Also Rises

            Algorithm, Mathematica, 計(jì)算機(jī)科學(xué), C++, photography, GNU/Linux的討論空間

              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              73 隨筆 :: 6 文章 :: 169 評(píng)論 :: 0 Trackbacks
            A Knights of the Round Table
            模型:
            給出一張圖(|V| <= 1000),求所有包含在奇數(shù)環(huán)中的點(diǎn)。
            算法分析:
            對(duì)每一個(gè)連通的子圖,找出圖中的割點(diǎn),然后這些割點(diǎn)可以將圖分為幾部分,對(duì)于每一部分,每個(gè)點(diǎn)都至少在一個(gè)環(huán)中,
            因此如果該部分存在一個(gè)奇數(shù)環(huán),則該部分所有點(diǎn)都屬于一個(gè)奇數(shù)環(huán)。
            對(duì)于某一個(gè)圖中是否存在奇數(shù)環(huán)的問題,只需黑白染色判斷是否是二分圖即可~
            復(fù)雜度|V| + |E|。
            注意那些度數(shù)<=1的點(diǎn),我的實(shí)現(xiàn)方法需要預(yù)先刪除這些點(diǎn)。
            CODE


            The Cow Doctor
            模型:
            給出m個(gè)集合,里面存在n種元素。求這些集合中可以被其他集合并得到的(精確相等)。
            m <= 200, n <= 300
            算法分析:
            設(shè)A能被其他集合B1, B2, ... Bi并得到,則B1, B2, ... Bi顯然都屬于A。
            因此,我們可以找出所有屬于A的集合B1, B2, ... Bi,求它們的并,看是否等于A。
            復(fù)雜度O(m ^ 2 * n),具體實(shí)現(xiàn)可以使用bitset :)

            C Wild West
            模型:
            給出n個(gè)長(zhǎng)方體(0, 0, 0) - (ai, bi, ci),求它們并的總體積。
            n, a, b, c <= 100000
            算法分析:
            首先想到用一個(gè)平行于xy的平面去截這些長(zhǎng)方體。方便起見我們從最大的c開始截。
            注意到保證所有長(zhǎng)方體必定是以(0, 0, 0)點(diǎn)作為一個(gè)頂點(diǎn)的,所以平面向下移動(dòng)的過程中截到的內(nèi)容只增不減。
            剩下的核心問題就是維護(hù)對(duì)長(zhǎng)方形序列(0, 0) - (ai, bi)并動(dòng)態(tài)報(bào)告它們的面積并。
            注意到必定以(0, 0)為一個(gè)節(jié)點(diǎn),所以我們每行只需要記錄延伸的長(zhǎng)度。
            用線段樹維護(hù)并且報(bào)告面積即可。
            復(fù)雜度O(nlogn)

            D Pixel Shuffle
            算出目標(biāo)置換,然后算出每個(gè)cycle的長(zhǎng)度,求LCM~
            Ural1024 Permutations 是一道單純計(jì)算置換多少次可以回到原始的題。
            ms就是Europe - Southwestern - 2005/2006的Pixel Shuffle,寒,歐洲人出題抄來抄去的。
            uva3510

            E Find the Clones
            弱題,排序再掃描。

            F The Warehouse
            算法分析:
            顯然是搜索。不過似乎官方數(shù)據(jù)不會(huì)太強(qiáng),如下的數(shù)據(jù)比賽的時(shí)候AC的程序就跑不出來。
            8 6 1
            E...2...
            ........
            ..222222
            ........
            ........
            22222222
            ........
            ..2..2..
            我用BFS + SET做的。似乎還可以DFS + 剪枝。
            CODE


            G Widget Factory
            算法分析:
            Gauss消元,注意判斷各種情況。
            復(fù)雜度O(n ^ 3)

            Martian Mining
            算法分析:
            首先可以證明,對(duì)任一個(gè)n * m的部分,或者最后一列都用來bloggium, 或者最后一行都用來yeyenum。于是就可以dp了。
            d[i, j] = 左上角的i * j部分的最大結(jié)果。
            則d[i, j] = max(d[i - 1, j] + 最后一行的yeyenum和, d[i, j - 1] + 最后一列的bloggium和)
            復(fù)雜度O(n * m)

            I Nuclear Plants
            模型:
            給出一張圖,求最大的平均環(huán)長(zhǎng)度。
            |V| <= 676, |E| <= 100000
            算法分析:
            我的算法是二分答案w, 然后將每個(gè)(u, v)邊權(quán)當(dāng)作w - len(u, v)來做,然后用Bellman-Ford判是否存在負(fù)權(quán)回路,存在說明可以,否則說明不可行。
            另外這個(gè)題有標(biāo)準(zhǔn)算法。見CLRS

            J Word Rings
            模型:
            經(jīng)典問題了。給出一堆圓,半徑只可能是r1 = 0.58 或 r2 = 1.31,求這些圓覆蓋的面積和。
            算法分析:
            此題比賽時(shí)沒有隊(duì)過。
            一種做法是解出所有交點(diǎn)連同圓的左右兩邊一起離散,切大條做,但傳說中圓解交點(diǎn)誤差很大……
            一份解題報(bào)告中提出的做法是每次把空間一切為四然后每部分的面積加起來,遞歸處理。如果某一部分只和一個(gè)圓相交那么用解析的方法算出其精確值。
            當(dāng)每部分小到一定程度的時(shí)候用類似于撒點(diǎn)隨機(jī)化之類的方法。


            posted on 2008-02-03 21:32 FreePeter 閱讀(1904) 評(píng)論(4)  編輯 收藏 引用 所屬分類: ACM/ICPC

            評(píng)論

            # re: Central Europe 2005解題報(bào)告 2008-02-25 11:08 crackerwang
            word rings 分完了之后再直接B-F好象過不了,直接SPFA好象也過不了.
            我寫法都直接按照書上寫的,B-F是做E次.SPFA是進(jìn)入隊(duì)列V次.是不是有什么剪枝或者改進(jìn)呢??  回復(fù)  更多評(píng)論
              

            # re: Central Europe 2005解題報(bào)告 2008-02-25 17:46 FreePeter
            @crackerwang
            要用二分的方法過這個(gè)題需要常數(shù)寫的比較小,我使用了臨接表 + 估計(jì)上下界 + SPFA + 放寬二分精度(只精確到1e-3)

            其實(shí)有一個(gè)標(biāo)準(zhǔn)做法,參見Introduction to Algorthms, P617, Karps' minimum mean-weight cycle algorithm.  回復(fù)  更多評(píng)論
              

            # re: Central Europe 2005解題報(bào)告 2008-08-18 06:33 ecnu_zp
            太感謝"圓桌騎士"的解釋了。。
            感激不盡. Orz  回復(fù)  更多評(píng)論
              

            # re: Central Europe 2005解題報(bào)告 2008-09-27 04:09 ecnu_zp
            Karps' minimum mean-weight cycle algorithm, 我的中文版,找了好久才找到。囧
            379 頁~~~~  回復(fù)  更多評(píng)論
              

            Creative Commons License
            This site is licensed under a Creative Commons Attribution-Share Alike 2.5 China Mainland License. 本站采用創(chuàng)作共用版權(quán)協(xié)議, 要求署名、相同方式共享. 轉(zhuǎn)載本站內(nèi)容必須也遵循“署名-相同方式共享”的創(chuàng)作共用協(xié)議. This site is licensed under a Creative Commons Attribution-ShareAlike 2.5 License.
            日本精品久久久中文字幕| 青青青伊人色综合久久| 亚洲中文久久精品无码| 亚洲AV乱码久久精品蜜桃| 色婷婷综合久久久久中文| A狠狠久久蜜臀婷色中文网| 久久精品国产免费一区| 久久精品国产一区二区三区不卡| 久久伊人亚洲AV无码网站| 狠狠色丁香久久婷婷综合_中| 亚洲国产精品久久久天堂| 国产精品美女久久久| 久久九色综合九色99伊人| 久久夜色精品国产噜噜亚洲a| 亚洲伊人久久大香线蕉综合图片| 2021精品国产综合久久| 国产精品热久久无码av| 2021国内久久精品| 97r久久精品国产99国产精| 久久精品人妻一区二区三区| 久久亚洲sm情趣捆绑调教| 国产精品久久久久久一区二区三区| 精品久久国产一区二区三区香蕉 | 国内精品久久久久影院日本| 久久久久久久99精品免费观看| 亚洲国产精品成人久久蜜臀 | a级成人毛片久久| 久久久噜噜噜久久| 色偷偷88888欧美精品久久久| 999久久久国产精品| 久久妇女高潮几次MBA| 久久成人精品视频| 精品国产乱码久久久久软件| 蜜桃麻豆www久久| 东方aⅴ免费观看久久av| 国产一区二区精品久久凹凸| 色88久久久久高潮综合影院| 久久人人爽人人爽人人片AV东京热 | 国产精品久久99| 久久久久亚洲AV无码专区首JN| 99久久www免费人成精品 |