青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 97, 文章 - 22, 評論 - 81, 引用 - 0
數(shù)據(jù)加載中……

South America 2002 解題報告

 

AGrandpa's Rubik Cube
       PKU 1290 http://poj.org/problem?id=1290

 

       題意:給定一個3X3的六面魔方(每個面有3X3個塊),求經(jīng)過某些旋轉之后能否使得所有面的顏色都相同,旋轉包括對某個面進行順時針和逆時針旋轉(共12種情況)。

A-1

       如圖1,輸入數(shù)據(jù)為左圖的形式,右圖給對應的面編號,箭頭方向為順時針旋轉方向。

+A表示對A這個面進行一次順時針旋轉,-B表示對B這個面進行一次逆時針旋轉。問經(jīng)過一定的+A/-B操作之后能否使得所有面的3X3個字母都相同。

 

       題解:模擬題

       做法很多,這里介紹一種比較容易理解的狀態(tài)記錄方式,考慮某次旋轉,一定是旋轉某個面,然后對鄰接的四個面的某條邊進行順次平移。如圖A-2, 2號面的旋轉帶動的是1536四個面。

A-2

       我用一個數(shù)組rotate_n來記錄某個面旋轉的時候帶動的面的編號集合(編號為0的數(shù)據(jù)為占位符),那么有:

int rotate_n [7][4] = {

    {0, 0, 0, 0}, {4, 5, 2, 6}, {1, 5, 3, 6}, {2, 5, 4, 6}, {3, 5, 1, 6}, {1, 4, 3, 2}, {1, 2, 3, 4}

};

       光記錄帶動的面是哪些還不夠,還需要知道帶動面的對應邊,對于一個魔方的一個面,我們編號如下:

0,0)(0,1)(0,2

1,0)(1,1)(1,2

2,0)(2,1)(2,2

       分別用14來代表一個面的四條邊(注意,有方向):

1 (0,2) - (0,0)

2 (2,2) - (0,2)

3 (2,0) - (2,2)

4 (0,0) - (2,0)

       那么同樣用rotate_p來記錄某個面旋轉的時候帶動的面對應的邊,則有:

int rotate_p[7][4] = {

       {0, 0, 0, 0}, {2, 4, 4, 4}, {2, 3, 4, 1}, {2, 2, 4, 2}, {2, 1, 4, 3}, {1, 1, 1, 1}, {3, 3, 3, 3},

};

       這樣一來,我們只需要考慮一個面的旋轉,然后套用對應的數(shù)據(jù)即可,還有一個比較巧妙的是,逆時針旋轉不需要特殊處理,直接將順時針旋轉執(zhí)行三次即可。

BThis Sentence is False
       
PKU 1291 http://poj.org/problem?id=1291

       題意:給定一些句子形如“Sentence X is true/false”的句子,X表示第幾個句子,問所有的情況是否合法,如果合法,輸出最大的可能為真的句子。

       題解:2-sat

       每個句子抽象成兩個結點,為真的時候為X,為假的時候為X '

       a) 對于第X個句子,如果是 Sentence Y is true

              則這個句子為真的時候, X ->Y連邊;

              當這個句子為假的時候,X ' -> Y '連邊;

       b) 對于第X個句子,如果是 Sentence Y is false

              則這個句子為真的時候, X ->Y '連邊;

              當這個句子為假的時候,X ' -> Y連邊;

       然后求一次強連通,如果最后有某個點XX ' 在同一個連通圖中,說明邏輯錯誤,說明必然存在不合法的情況,否則對于每個連通分量,求出為真的點的個數(shù)和為假的點的個數(shù),然后將他們之中的大者累加,最后答案除2就是最大的可能為真的句子(除2的原因是因為真假是對稱的)。

CWill Indiana Jones Get There?
       
PKU 1292 http://poj.org/problem?id=1292

       題意:營救公主,營救路線要么繞著墻走,要么走兩面墻的最短距離(這種情況下需要在兩面墻之間搭一塊木板,并且可以反復使用)。問營救過程中木板的最短長度。

C-1

       題解:線段距離 + 二分答案

       因為木板可以反復使用,所以我們可以假設如果木板越長,能夠營救公主的概率就越大,反之則越小,所以問題就是求滿足兩點可達的最小木板長度,可以二分枚舉這個長度T,如果兩面墻的最短距離大于這個T,表明兩面墻不可達,將墻抽象成點,兩面墻之間的最短距離可以通過線段和線段的最短距離預處理出來,然后每次二分答案后通過一次搜索就可以找出起點和終點是否可達,復雜度為On^2)即計算兩線段距離時候的復雜度。

 

D. Duty Free Shop
       
PKU 1293 http://poj.org/problem?id=1293

       題意:給定M(M <= 1000)個白巧克力和L(L<= 1000)個黑巧克力,然后給定N(N <= M + L)個容量為Ci的盒子,問能否找到一種方案,使得某些盒子放滿白巧克力,剩下的盒子放滿黑巧克力。

       題解:背包問題。

       由于需要將每個盒子都放滿,于是可以利用一維背包的求法將Ci的所有小于等于M的可行組合求出來,找到最大的M ' <= M,并且M ' 能夠通過某種方式被組合出來,那么所有盒子的容量Sum 減去 M ' 的差小于等于L的話,必定能將剩下的盒子填滿黑巧克力,否則無解。

       這題需要記錄前驅,并且注意M = 0 以及 L = 0 的情況(主要是在輸入的時候判斷退出條件,M+L==0退出而并非 (M&&L) == 0)。

 

ENot Too Convex Hull
       
PKU 1294 http://poj.org/problem?id=1294

       題意:給定N(N<=101)個點(沒有三點共線的情況),要求用B(B<=50)根皮條將這N個點圈成B個部分,每個部分為一個凸多邊形,并且所有凸多邊形公用一個點(這個點會給出),求眾多方案中滿足所有多邊形面積和最小的方案。圖E-1表示用兩根皮條圈住19個點的情況(原點共用了兩次)。

E-1

       題解:環(huán)形動態(tài)規(guī)劃。

       首先將所有點按照給定的原點進行極坐標排序,那么第1個點到第N個點必定是按照極坐標嚴格逆時針排布的(因為沒有三點共線),用DP[i][b]表示第i個點到第N個點經(jīng)過b次分割后分割完的凸多邊形的面積總和最小值,那么:

DP[i][b] =min{ area[i][k] +DP[k+1][b-1]   (i < k < N) }; 特殊的,DP[0][0] = 0;

     area[i][j] 表示極坐標在第i個點和第j個點之間的所有點(包含這兩個點)加上原點組成的凸包的面積,可以通過初始化預處理出來;

     由于點是極坐標排列的,也就是第一個點不一定是凸包邊上的點(有可能是第N-1個點到第2個點組成的凸包達到整體最優(yōu)),所以需要做NDP,可以將所有點復制一份,枚舉起點i ( 1 <= i <= N),終點即i+N, 然后分別做一次DP取最小值。

     時間復雜度O(N^2 * B)

 

FI hate SPAM, but some people love it
       
PKU 1295 http://poj.org/problem?id=1295

       題意:N(N<=20)個人互發(fā)郵件,某個人收到郵件后一定會回復給他所有的好友,回復的數(shù)量決定他的稱號,按順序給定首先發(fā)起郵件的人,要求按順序輸出所有人得到的稱號。

       題解:深搜枚舉。

       數(shù)據(jù)量很小,對于給定的初始者作為起點進行遍歷,每個人只訪問一次,訪問到的時候根據(jù)他的朋友數(shù)量計算他的稱號即可。

 

GNoise Effect
       
PKU 1296 http://poj.org/problem?id=1296

       題意:給定兩個正方形矩陣,求他們的最大相似度,相似度的定義為矩陣元素對應位差值小于等于100的個數(shù)占所有矩陣元素的百分比(可以進行旋轉和翻轉)。

       題解:模擬題。

       每個矩陣可以進行四次旋轉,每次旋轉可以有水平翻轉、豎直翻轉、水平豎直翻轉、保持原樣四種狀態(tài),一共十六種情況(實際小于16種,因為有些狀態(tài)經(jīng)過翻轉和旋轉之后是一樣的),對每種情況模擬計算相似度取最大值即可。

 

HSupermarket
      
 PKU 1297 http://poj.org/problem?id=1297

       題意:約翰需要買M(M<=100)件物品,超級市場上的物品都排成一排,一共N(N<=100000)件物品,他從左向右開始選物品,但是為了不麻煩,不想走回頭路,而且第i個物品買的條件是,前i1個物品必須已經(jīng)買了,但是每個物品在超級市場中的價格不一樣,即使同一個物品也有不同的價格,為了花費最少,他想要一個方案使得:

       1) 按順序購買M個物品;

       2) 總價值最少,并輸出這個最小值,如果方案不存在,輸出Impossible

 

       題解:動態(tài)規(guī)劃。

       DP[i][j]表示第i個購買列表中的物品和第j個市場中的物品匹配時的最小消費(1<=i<=M,1<=j<=N;

       Min[i][j]表示min{ DP [i][x]  x<=j };

    a)當?shù)?/span>i個物品和第j個市場物品編號相同時,DP[i][j] = Min[i-1][j-1] +cost[j];

       b)否則DP[i][j] = inf; 計算DP數(shù)組同時更新Min數(shù)組,由于每次的狀態(tài)最多和上一行有關,所以在進行狀態(tài)轉移的時候可以采用滾動數(shù)組。時間復雜度O(NM)

 

posted on 2014-05-18 17:10 英雄哪里出來 閱讀(1061) 評論(2)  編輯 收藏 引用 所屬分類: 區(qū)域賽 解題報告

評論

# re: South America 2002 解題報告  回復  更多評論   

前輩的博客終于更新了
2014-05-25 04:09 | 晴天小豬

# re: South America 2002 解題報告  回復  更多評論   

呵呵,好久沒做題了~最近興起又開始做了~~@晴天小豬
2014-05-25 09:09 | 英雄哪里出來
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲综合色激情五月| 亚洲免费综合| 欧美精品免费播放| 日韩视频久久| 亚洲影视中文字幕| 国产一区二区在线观看免费播放 | 亚洲精选久久| 亚洲人成网站在线观看播放| 欧美精品色网| 午夜精品免费在线| 亚洲欧美在线播放| 激情欧美日韩一区| 欧美国产一区在线| 国产精品久久久久av免费| 欧美一区在线看| 久久久久久91香蕉国产| 99pao成人国产永久免费视频| aⅴ色国产欧美| 极品日韩av| 夜夜嗨av色综合久久久综合网| 国产欧美在线观看一区| 欧美寡妇偷汉性猛交| 国产精品久久久久久五月尺| 久久伊人一区二区| 欧美日韩在线一区二区三区| 麻豆精品一区二区综合av| 欧美日韩免费观看中文| 久久久久久久久久久一区| 欧美日本在线| 老司机午夜精品视频在线观看| 欧美日韩成人激情| 久久亚洲国产精品日日av夜夜| 久久久久久久久伊人| a4yy欧美一区二区三区| 久久久久国产精品一区| 亚洲专区在线| 欧美激情一区二区三区在线| 久久久久天天天天| 欧美午夜精品久久久久久人妖 | 亚洲一二三区视频在线观看| 国产日韩精品视频一区二区三区 | 亚洲视频精选在线| 久久精品二区亚洲w码| 亚洲一区二区三区三| 老牛嫩草一区二区三区日本| 久久久久久亚洲精品中文字幕 | 欧美日韩一区二区三区在线观看免 | 欧美午夜精品电影| 亚洲国产精品一区在线观看不卡| 国产欧美一区二区精品性色| 夜色激情一区二区| 一本综合精品| 欧美视频在线不卡| 亚洲乱码久久| 一本久道综合久久精品| 欧美a一区二区| 亚洲电影成人| 亚洲精品久久在线| 欧美高清视频| 亚洲精品国产拍免费91在线| 亚洲欧洲一区二区在线播放| 久久精品中文字幕免费mv| 久久久久久久综合日本| 国产欧美午夜| 欧美一区二区三区视频免费播放 | 麻豆精品一区二区av白丝在线| 国产欧美日韩在线视频| 亚洲欧美成人精品| 久久九九热免费视频| 国内一区二区三区在线视频| 久久久亚洲午夜电影| 免费久久99精品国产自| 亚洲第一黄色网| 欧美精品亚洲精品| 日韩天堂av| 欧美与黑人午夜性猛交久久久| 国产嫩草影院久久久久| 久久精品国产一区二区电影 | 一区二区久久| 久久国产精品一区二区| 激情久久综艺| 欧美伦理在线观看| 亚洲欧美精品伊人久久| 久久麻豆一区二区| 亚洲乱码精品一二三四区日韩在线 | 亚洲黄色影片| 亚洲在线成人精品| 国产在线观看一区| 欧美www在线| 亚洲系列中文字幕| 久久久久久久精| 日韩午夜激情av| 国产美女精品| 欧美精品一区二区蜜臀亚洲| 一区二区三区视频在线播放| 午夜在线视频观看日韩17c| 欧美在线一级视频| 亚洲人成在线观看一区二区| 欧美日韩一区二区在线观看视频 | 久久欧美肥婆一二区| 亚洲日本一区二区| 国产午夜精品全部视频播放| 欧美成人免费全部| 欧美一区观看| 一区二区冒白浆视频| 免费看av成人| 性18欧美另类| 亚洲香蕉视频| 亚洲欧洲日本国产| 国产无一区二区| 欧美日韩国产精品自在自线| 久久九九全国免费精品观看| 99视频一区二区三区| 免费观看亚洲视频大全| 亚洲欧美日韩成人| 日韩视频一区二区在线观看| 国产一区在线播放| 国产精品成av人在线视午夜片| 奶水喷射视频一区| 欧美制服第一页| 亚洲一线二线三线久久久| 亚洲美女视频在线免费观看| 男女激情久久| 久久亚洲综合| 久久综合九色综合欧美就去吻 | 9l国产精品久久久久麻豆| 精品99视频| 国产一区二区三区视频在线观看| 国产精品成人一区二区| 欧美精品日韩一本| 蜜桃久久精品一区二区| 久久久久久国产精品mv| 欧美一区亚洲| 欧美一区二区三区啪啪| 欧美一级久久| 欧美在线视屏| 久久精品麻豆| 久久精品视频在线| 久久字幕精品一区| 美女亚洲精品| 欧美阿v一级看视频| 欧美韩日一区| 欧美日韩国产成人高清视频| 欧美日本一区二区高清播放视频| 欧美人体xx| 欧美日韩亚洲视频| 国产精品v日韩精品v欧美精品网站| 欧美三级视频在线播放| 欧美手机在线视频| 国产精品一区一区三区| 国产伦精品一区二区| 国产亚洲欧洲一区高清在线观看| 国产日韩欧美中文在线播放| 国产日韩欧美综合在线| 狠狠色丁香久久婷婷综合_中| 韩国欧美国产1区| 亚洲国产精品悠悠久久琪琪| 最新亚洲一区| 亚洲综合电影一区二区三区| 欧美一区二区三区的| 久久人人97超碰精品888| 欧美成人免费小视频| 亚洲日本中文字幕免费在线不卡| 亚洲精品中文字幕女同| 亚洲一区二区在线看| 久久精品在这里| 欧美日韩在线观看一区二区三区| 国产精品草草| 在线观看福利一区| 这里只有精品视频| 久久精品国产亚洲精品| 亚洲国产高清一区| 亚洲欧美久久久久一区二区三区| 午夜亚洲伦理| 欧美亚洲日本一区| 美日韩在线观看| 亚洲精品视频在线| 欧美一区二视频| 欧美日韩高清区| 在线观看国产精品网站| 亚洲在线视频| 欧美激情视频一区二区三区不卡| 99视频有精品| 欧美不卡三区| 国产亚洲精品综合一区91| 亚洲久久视频| 久久综合网络一区二区| 亚洲视频在线观看网站| 老司机精品导航| 国产麻豆9l精品三级站| 亚洲免费观看| 麻豆国产精品一区二区三区| 亚洲一二三四久久| 欧美剧在线免费观看网站| 国模精品一区二区三区色天香| 一区二区三区国产| 亚洲第一中文字幕| 久久精品国产欧美激情| 国产精品久久网| 亚洲一区二区三区视频播放|