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

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


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

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

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

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

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


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

            Martian Mining
            算法分析:
            首先可以證明,對任一個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)長度。
            |V| <= 676, |E| <= 100000
            算法分析:
            我的算法是二分答案w, 然后將每個(u, v)邊權(quán)當(dāng)作w - len(u, v)來做,然后用Bellman-Ford判是否存在負(fù)權(quán)回路,存在說明可以,否則說明不可行。
            另外這個題有標(biāo)準(zhǔn)算法。見CLRS

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


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

            評論

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

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

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

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

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

            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.
            久久综合综合久久狠狠狠97色88| 久久精品国产日本波多野结衣| 久久精品成人免费看| 99久久精品免费看国产一区二区三区| 精品综合久久久久久97超人| 久久精品国产99久久久香蕉| 久久精品无码一区二区WWW| 亚洲综合伊人久久综合| 大蕉久久伊人中文字幕| 亚洲欧洲日产国码无码久久99| 99久久99久久精品国产片| 久久久亚洲欧洲日产国码是AV | 久久高潮一级毛片免费| 久久福利资源国产精品999| 国产精品女同久久久久电影院| 久久亚洲AV永久无码精品| 久久久久久久人妻无码中文字幕爆 | 蜜桃麻豆www久久| 婷婷久久香蕉五月综合加勒比| 99久久精品国产综合一区| 久久精品国产亚洲AV大全| 国产精品久久久久久久app| 国产成人久久久精品二区三区| 亚洲精品无码久久久久久| 国内精品综合久久久40p| 久久性精品| 久久综合九色综合久99| 精品久久久无码中文字幕天天 | 77777亚洲午夜久久多喷| 久久精品无码免费不卡| 亚洲中文字幕无码久久2020| 色婷婷综合久久久久中文字幕| 91久久精品视频| 欧美久久综合性欧美| 久久不见久久见免费视频7| 日本久久久久亚洲中字幕| 人妻久久久一区二区三区| 国内精品久久人妻互换| 久久99精品久久只有精品| 久久精品人人做人人妻人人玩| 奇米综合四色77777久久|