• <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>
            posts - 11, comments - 2, trackbacks - 0, articles - 0

            Waterloo local contest 1998

            Posted on 2009-03-01 23:17 hello_world 閱讀(1324) 評論(0)  編輯 收藏 引用
            Waterloo local 1998.10.17
            Prime Distance
            簡單刷表
             Yahtzee  DP
             Request for Proposal  簡單題
             Australian Voting  模擬
            Chocolate Chip Cookies geometry


             Prime Distance

             題目大意就是給你一個區間[l,r],找出這里相鄰素數的最大距離和最小距離
             刷表是經典而實用的方法


            Yahtzee
            給十三種5個骰子的狀態,十三種規則,每種規則下每個狀態有一個得分,問怎樣分配規則與狀態之間的對應關系,讓得分最大,同時要注意的是如果前六種規則下的得分如果>=63,那么總得分要加上35!
            首先預處理出每種規則下每個狀態的得分情況!
            如果沒有最后一個限制,那么我們可以有兩種做法:1,二分圖的最大權匹配;2,DP!但是有了最后一個限制,用匹配的話不知怎么下手,我只能想到dp!dp[i][j][k]表示前i種骰子狀態已經分配好,分配的情況壓縮成一個整數j,并且前六種規則的得分是k的狀態,那么狀態轉移就是 dp[i][j][k] = {max(dp[ i - 1 ][ j - (1<<h) ][ k - score[h][i] ] ) (0<=h<=6),max(max(dp[ i - 1 ][ j - (1<<h) ][ k ])( 7<=h<13) } (j的第h位為1) ! 復雜度大概是13*2^13*64 ; 中間記錄前一個狀態, 最后遞歸輸出就好了~
             
            Request for Proposal:

            Australian Voting:
            按照題意模擬就好了~

             Chocolate Chip Cookies

             題目大意就是有一些點(200個), 用一個給定半徑(r==5cm)的圓,最多能罩住多少個點
             200個點的話 o ( n^3 )能過,這樣我們有了算法,要罩住最多的點,那個圓必須至少要住兩個點
             枚舉每兩個點確定圓心,在檢查所有的點是否在圓內。想法很自然
             細節問題上就是如何找到圓心(確定半徑和兩個圓上的點)這是基本功
             
             如果說直接解方程有些繁瑣這里有好方法:

             
             這樣只要解二元一次方程,可參考以下代碼:
             1 struct point {double x, y;};
             2 
             3 bool centre(point p, point q, double r,point &o1, point &o2)
             4 //兩點一半徑會確定兩個圓心 o1 o2
             5 {
             6    double rise,run,theta;
             7    double chordlen, perplen;
             8    double tantheta,tantheta1;
             9  
            10    chordlen = sqrt( (p.x-q.x)*(p.x-q.x) + (p.y-q.y)*(p.y-q.y) );
            11    if (chordlen > 2*r) { return false; }
            12    tantheta = sqrt(r*r*4 - chordlen*chordlen)/(chordlen);
            13    //圓心角<poq的半角的正切值 
            14 
            15    run = (p.x-q.x)/2;
            16    rise = (p.y-q.y)/2;
            17    o1.x= (p.x+q.x)/2 + rise * tantheta;
            18    o1.y= (p.y+q.y)/2 + -run * tantheta;
            19    o2.x= (p.x+q.x)/2 + -rise * tantheta;
            20    o2.y = (p.y+q.y)/2 + run * tantheta;
            21   //結合點積就能得出上式
            22    return true;
            23 }
            24 

            一级做a爱片久久毛片| 久久久久亚洲AV无码专区网站| 久久久亚洲AV波多野结衣| 伊人久久大香线蕉综合影院首页| 亚洲综合精品香蕉久久网| 精品综合久久久久久97超人| 性做久久久久久久久老女人| 乱亲女H秽乱长久久久| 国产精品日韩欧美久久综合| 国产成人综合久久精品红| 久久精品国产一区二区三区日韩| 久久天天躁狠狠躁夜夜2020| 久久99国内精品自在现线| 久久久久黑人强伦姧人妻| 久久婷婷成人综合色综合| 久久人人爽人人爽人人片AV麻豆| 国产亚洲精久久久久久无码| 久久激情五月丁香伊人| 国内精品久久国产大陆| 97久久婷婷五月综合色d啪蜜芽| 久久国产精品久久精品国产| 伊人久久大香线蕉av一区| 久久久91人妻无码精品蜜桃HD| MM131亚洲国产美女久久| 亚洲午夜久久久久妓女影院| 久久伊人色| 久久99精品免费一区二区| 久久久精品午夜免费不卡| 久久亚洲私人国产精品vA| 亚洲午夜久久久久久久久久| 久久久久久久精品妇女99| 无码任你躁久久久久久老妇App| 成人午夜精品久久久久久久小说 | 久久午夜羞羞影院免费观看| 久久久精品国产| 香蕉久久夜色精品国产尤物| 色悠久久久久久久综合网| 国产精品亚洲综合久久| 模特私拍国产精品久久| 伊人久久无码中文字幕| 亚洲精品乱码久久久久久蜜桃图片 |