北京大學(xué)ACM國際大學(xué)生程序設(shè)計競賽.ppt
《北京大學(xué)ACM國際大學(xué)生程序設(shè)計競賽.ppt》由會員分享,可在線閱讀,更多相關(guān)《北京大學(xué)ACM國際大學(xué)生程序設(shè)計競賽.ppt(23頁珍藏版)》請在裝配圖網(wǎng)上搜索。
問題求解與程序設(shè)計第七講搜索,李文新2004.22004.6,內(nèi)容提要,搜索討論1011stick討論1054thetroublesomefrog參考王知昆的冬令營報告作業(yè),搜索的一般概念,在解空間中嘗試所有可能,找出滿足條件的取值回顧填數(shù)游戲:1-9填在3*3的表格中,使得行、列、對角線的和均為15。方程組搜索逐一嘗試+剪枝,題目討論,1011stick,題目討論,TheTroublesomeFrogIOI2002day1task1,問題,稻田,問題,青蛙從外面跳入稻田,踩過一些禾苗,后,跳出稻田。,問題,蛙路:一個方向,等間距,大于等于3個點不同蛙路:可以方向不同,間距不同,問題,許多青蛙跳過稻田,形成多條蛙路,不同蛙路可以踩過同一作物。,問題,青蛙每天早上踩壞稻田,早上人們發(fā)現(xiàn)稻田有若干株作物被踩壞,但不知多少青蛙來過。也有不在蛙路上的被踩壞的作物。,問題,問,給定一塊被踩壞的稻田,求可能的最長的蛙路上被踩壞的作物的數(shù)目。,輸入,第一行整數(shù)R和C,稻田的行數(shù)和列數(shù)第二行整數(shù)N,表示被踩壞的作物總數(shù)。后續(xù)N行,每行兩個整數(shù)i,j為被踩壞的作物的行和列的位置:1=i=R,1,1=j=C。每個被踩壞的作物只出現(xiàn)一次。,輸出,單個整數(shù)-表示最長可能蛙路上踩壞的作物數(shù)目,樣例,Figure-4,問題的解,這道題目也就是說,在給出的n個點中找出一些點的序列來,使得每一個點相對于上一個點的坐標(biāo)都是一個相同的向量,且第一個點減去這個向量和最后一個點加上這個向量后均落在方格的外面。,問題的解,我們先對這些點按照坐標(biāo)排序。然后依次循環(huán)出要求的序列中的第一個和第二個點,這樣我們就知道后一個點相對于前一個點的坐標(biāo)是多少了。然后我們依次用第二個點加上這個坐標(biāo)的出第三個點,第三個點加上這個坐標(biāo)得出第四個點等等。當(dāng)然,我們還需要判斷一下這求出來的第三個、第四個點是否在給定的點內(nèi)。,問題的解,由于每個點的上一個點/下一個點最多只能有n種選擇,故一個點最多屬于n條不同的蛙路。這樣,對于某個確定的點來說,它的所有可能的下一個需要判斷的點至多有n個。這樣因為判斷一個點在不在給定的點內(nèi)只需要O(1)的復(fù)雜度,所以我們只需要O(n2)的時間就可以得出問題的解答。由于這個算法需要一個r*c的表來保存點在方格中的存在狀態(tài),故空間復(fù)雜度為O(n2)。,問題的解,需要注意的是,蛙路中的點數(shù)少于3個的時候是不考慮的。所以這個時候的蛙路中的點數(shù)應(yīng)該按照0來算。,實現(xiàn)細節(jié),Frogvsfrog平面上點的表示Frog20有冗余代碼Frog21去掉冗余Frog22compare判斷Frog23改變表達式寫法Frog24增加剪枝Frog25不太好的剪枝順序Frog26較好的剪枝順序,測試數(shù)據(jù),No.N,(R*C)DescriptionSolution118,(6*7)Sampledatainthetaskdescription4210,(10*10)Manuallydesigned5325,(50*50)Manuallydesigned13450,(10*10)SeveralLines+randompoints105100,(20*20)modifiedrandompointset106300,(30*30)modifiedrandompointset157500,(55*55)SeveralLines+randompoints288500,(100*100)Specialcasefornosolution091000,(100*100)SeveralLines+randompoints34101000,(1000*1000)SeveralLines+randompoints250112000,(50*50)Random(uniform)points25122000,(100*200)SeveralLines+randompoints33132000,(1000*2000)SeveralLines+randompoints333,測試數(shù)據(jù),143000,(60*60)Uniformlyrandompoints31153000,(500*500)Xshapesandrandompoints500163000,(5000*1)Horizontalline20173000,(5*1000)SeveralLines+randompoints17184000,(100*100)Randompoints(uniformly)34194000,(200*20)Verydensepointsset200204000,(1000*1000)SeveralLines+randompoints500214000,(5000*5000)SeveralLines+randompoints311225000,(100*100)Chessboardstyle100235000,(1000*1000)SeveralLines+randompoints334245000,(3000*3000)Irregularlinearpoints1000255000,(5000*5000)Modifiedrandompoints72,參考資料,王知昆的冬令營報告,作業(yè),10111054選做,- 1.請仔細閱讀文檔,確保文檔完整性,對于不預(yù)覽、不比對內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請點此認(rèn)領(lǐng)!既往收益都歸您。
下載文檔到電腦,查找使用更方便
9.9 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標(biāo),表示該PPT已包含配套word講稿。雙擊word圖標(biāo)可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計者僅對作品中獨創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 北京大學(xué) ACM 國際 大學(xué)生 程序設(shè)計 競賽
鏈接地址:http://italysoccerbets.com/p-11492831.html