• <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, 計算機科學, C++, photography, GNU/Linux的討論空間

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


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

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

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

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

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


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

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

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

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


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

            評論

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

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

            其實有一個標準做法,參見Introduction to Algorthms, P617, Karps' minimum mean-weight cycle algorithm.  回復  更多評論
              

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

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

            Creative Commons License
            This site is licensed under a Creative Commons Attribution-Share Alike 2.5 China Mainland License. 本站采用創作共用版權協議, 要求署名、相同方式共享. 轉載本站內容必須也遵循“署名-相同方式共享”的創作共用協議. This site is licensed under a Creative Commons Attribution-ShareAlike 2.5 License.
            久久久久国产精品| 国产精品久久精品| 久久夜色精品国产噜噜亚洲a | 久久精品无码专区免费青青| 久久狠狠色狠狠色综合| 久久久久久国产精品无码下载 | 亚洲AV成人无码久久精品老人| av午夜福利一片免费看久久| 久久久久亚洲精品无码网址| 久久亚洲精精品中文字幕| 99久久国产综合精品五月天喷水 | 九九久久精品无码专区| 99久久夜色精品国产网站 | 亚洲国产另类久久久精品| 欧美激情精品久久久久| 亚洲AV日韩精品久久久久| 久久久国产精品| 精品久久一区二区| 亚洲AV无码成人网站久久精品大| 久久精品成人| 午夜不卡888久久| 久久超碰97人人做人人爱| 久久中文字幕人妻熟av女| 狠狠久久综合| 色综合久久精品中文字幕首页| 久久夜色精品国产噜噜亚洲AV| 亚洲综合久久夜AV | 日韩精品国产自在久久现线拍| 日韩精品久久无码中文字幕| 久久人妻AV中文字幕| 欧美成人免费观看久久| 人人狠狠综合88综合久久| 久久久久亚洲精品男人的天堂| 国产三级精品久久| 国产香蕉97碰碰久久人人| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品99久久久精品无码| 伊人久久一区二区三区无码| 青青热久久国产久精品 | 久久成人影院精品777| 久久99国内精品自在现线|