• <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.
            青青草原综合久久大伊人| 中文字幕无码免费久久| 99精品久久精品一区二区| 青青青国产精品国产精品久久久久| 国产成人精品综合久久久| 人妻丰满?V无码久久不卡| 久久精品国产亚洲AV影院| 久久国产精品-久久精品| 日本加勒比久久精品| 久久精品人人槡人妻人人玩AV| 久久97久久97精品免视看秋霞| 国产精品久久久久久久app| 9久久9久久精品| 少妇被又大又粗又爽毛片久久黑人| 亚洲AV乱码久久精品蜜桃| 国产呻吟久久久久久久92| 一本色道久久88精品综合| 久久99精品久久久久久秒播| 亚洲AV日韩精品久久久久久| 香蕉久久永久视频| 久久这里只有精品久久| 久久青青草原亚洲av无码app| 色综合久久久久| 精品久久777| 久久精品人人槡人妻人人玩AV| 亚洲精品午夜国产va久久| 日韩亚洲欧美久久久www综合网| 亚洲国产欧洲综合997久久| 亚洲国产天堂久久综合| 情人伊人久久综合亚洲| 精品久久久久久久无码| 久久久久久久97| 亚洲色大成网站www久久九| 久久久亚洲AV波多野结衣| 香蕉久久久久久狠狠色| 欧美精品福利视频一区二区三区久久久精品 | 亚洲国产成人久久精品动漫| 一本色综合网久久| 香蕉久久av一区二区三区| 亚洲欧美伊人久久综合一区二区| 亚洲一级Av无码毛片久久精品|