• <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>
            隨筆-21  評論-10  文章-21  trackbacks-0
             1 /*
             2 23:15 - 0:22
             3 12:10 - 12:46
             4 22:00 - 0:00
             5 總共3:30小時
             6 1 由于點集是圍繞原點逆時針排好序,直接可以graham
             7 2 dp[i][j][k]表示用i根皮筋去綁以i開始的連續j個點的最小面積,狀態清晰
             8 3 代碼中能做優化是很強大的能力
             9 */
            10 
            11 #include<iostream>
            12 #include<cstring>
            13 #include<cstdio>
            14 #include<algorithm>
            15 #include<cmath>
            16 using namespace std;
            17 
            18 const int maxn = 150;
            19 
            20 struct Point{
            21    int x, y;
            22    bool operator<(const Point &a)const
            23    {
            24        return atan2(y + 0.0, x + 0.0< atan2(a.y + 0.0 , a.x + 0.0);
            25    }
            26 }p[maxn];
            27 int B, N, area;
            28 Point zero;
            29 int dp[55][maxn][maxn];
            30 
            31 int det(Point a, Point b, Point c){
            32     return (a.x - c.x)*(b.y - c.y) - (a.y - c.y)*(b.x - c.x);
            33 }
            34 
            35 int calc(int from, int to){
            36     int cnt = 0, area = 0;
            37     Point stack[maxn];
            38     for(int i = from; i < to; i++){
            39         while(cnt >= 2 && det(p[i % N], stack[cnt-1], stack[cnt-2]) > 0)cnt--;
            40         stack[cnt++= p[i % N];
            41     }
            42     for(int i = 0; i < cnt-1; i++)
            43         area += det(stack[i], stack[i+1], zero);
            44     return area;
            45 }
            46 
            47 void solve(){
            48     area = -1;
            49     memset(dp, -1sizeof(dp));
            50     for(int i = 0; i < N; i++)
            51         for(int j = 2; j <= N; j++){
            52            if(det(p[i], p[(i+j-1)%N], zero) < 0)break;
            53            dp[1][i][j] = calc(i, i + j);
            54            //cout<<i<<" "<<j<<" "<<dp[1][i][j]<<endl;
            55         }
            56         for(int k = 2; k <= B; k++){
            57            for(int i = 0; i < N; i++)
            58                for(int j = 2*k; j <= N; j++)
            59                {
            60                    for(int q = 2; q <= j - 2*(k-1); q++)
            61                    {
            62                        if(dp[k-1][(i+q)%N][j - q]==-1)continue;
            63                        if(dp[1][i][q]==-1)continue;
            64                        int t = dp[1][i][q] + dp[k-1][(i+q)%N][j - q];
            65                        if(t < dp[k][i][j] || dp[k][i][j]==-1)dp[k][i][j] = t;
            66                    }
            67                }
            68         }
            69         for(int i = 0; i < N; i++)
            70             if( dp[B][i][N]!=-1 && (dp[B][i][N] < area || area==-1) )
            71                 area = dp[B][i][N];
            72 }
            73 
            74 int main(){
            75     zero.x = zero.y = 0;
            76     while(scanf("%d %d",&B, &N) &&(B + N)){
            77          int x0, y0;
            78          scanf("%d %d",&x0, &y0);
            79          for(int i = 0; i < N-1; i++){
            80              scanf("%d %d",&p[i].x, &p[i].y);
            81              p[i].x -= x0;
            82              p[i].y -= y0;
            83          }
            84          sort(p, p + (--N) );
            85          solve();
            86          printf("%.2lf\n",area * 0.5);
            87     }   
            88 }
            89 

            posted on 2009-10-27 00:09 wangzhihao 閱讀(247) 評論(0)  編輯 收藏 引用 所屬分類: geometry
            青青青伊人色综合久久| 一本久久免费视频| 久久精品国产亚洲AV无码麻豆| 国内精品久久久久久久久电影网 | 国产香蕉久久精品综合网| 2021久久精品免费观看| 99久久99久久久精品齐齐| 激情久久久久久久久久| 无码超乳爆乳中文字幕久久 | 成人综合久久精品色婷婷| 国产精品久久波多野结衣| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 亚洲精品国产字幕久久不卡| 爱做久久久久久| 久久99热只有频精品8| 热久久视久久精品18| 777久久精品一区二区三区无码| 伊人久久一区二区三区无码| 青青青伊人色综合久久| 精品久久久久久无码专区 | 国产日韩久久久精品影院首页| 亚洲国产一成人久久精品| 亚洲人AV永久一区二区三区久久 | 国产精品久久久久久久午夜片| 性高湖久久久久久久久| 欧美日韩久久中文字幕| 久久久久久国产a免费观看不卡| 免费观看久久精彩视频| 国产成人精品久久二区二区| 欧美噜噜久久久XXX| 久久精品亚洲一区二区三区浴池| 久久久久久久精品成人热色戒| 欧美亚洲另类久久综合婷婷| 久久高潮一级毛片免费| 久久久久久亚洲精品不卡| 久久精品中文字幕有码| 久久久久国产精品麻豆AR影院| 老司机午夜网站国内精品久久久久久久久 | 久久精品99久久香蕉国产色戒| 久久精品国产男包| 久久久亚洲欧洲日产国码aⅴ|