• <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>

            pku 1020

            2009年8月7日

            題目鏈接:PKU 1020 Anniversary Cake
             
            分類:DFS應(yīng)用

            題目分析與算法原型:
                     題目大意就是給你些整邊長小正方形問你能否拼成一個(gè)給定的整邊長的大正方形。看數(shù)據(jù)范圍和題目類型,可以知道,先判斷一下所有小正方形面積之和是否恰為s^2之后,就應(yīng)該dfs了.
                    大致做法是:按從左到右從上到下的順序來放小正方形,先將大正方形看成一個(gè)二維數(shù)組,定義一個(gè)數(shù)組hang[],hang[i]表示第i列前面的hang[i]行已經(jīng)被占用了,然后先找到hang[i]最小的那個(gè)以它作為下一個(gè)放正方形的左上頂點(diǎn),接著每次從大到小枚舉所剩的正方形看能否放入(可以直接從10到1枚舉小正方形的邊長),若能放入,再接著DFS.......        

            Code:

             1
            #include<stdio.h>
             2#include<string.h>
             3int t,s,n,hang[42],c[11];
             4bool dfs(int num)
             5{
             6    int i,j,minpos=41,lie;
             7    if(num==n)return true;
             8    for(i=1;i<=s;i++)
             9        if(hang[i]<minpos)
            10        {
            11            minpos=hang[i];
            12            lie=i;
            13        }

            14    for(i=10;i>=1;i--)
            15        if(c[i]&&minpos+i<=s&&lie+i-1<=s)
            16        {
            17            for(j=lie;j<=lie+i-1;j++)if(hang[j]>minpos)break;
            18            if(j>lie+i-1)
            19            {
            20                c[i]--;
            21                for(j=lie;j<=lie+i-1;j++)hang[j]+=i;
            22                if(dfs(num+1))return true;
            23                for(j=lie;j<=lie+i-1;j++)hang[j]-=i;
            24                c[i]++;
            25            }

            26        }

            27        return false;
            28}

            29int main()
            30{
            31    int i,sum,size;
            32    scanf("%d",&t);
            33    while(t--)
            34    {
            35        scanf("%d%d",&s,&n);
            36        memset(hang,0,sizeof(hang));
            37        memset(c,0,sizeof(c));
            38        sum=0;
            39        for(i=1;i<=n;i++)
            40        {
            41            scanf("%d",&size);
            42            c[size]++;
            43            sum+=size*size;
            44        }

            45        if(sum!=s*s)printf("HUTUTU!\n");
            46        else 
            47        {
            48            if(dfs(0))printf("KHOOOOB!\n");
            49            else printf("HUTUTU!\n");
            50        }

            51    }

            52    return 1;
            53}

            posted on 2009-08-07 20:40 蝸牛也Coding 閱讀(317) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            <2009年7月>
            2829301234
            567891011
            12131415161718
            19202122232425
            2627282930311
            2345678

            導(dǎo)航

            統(tǒng)計(jì)

            常用鏈接

            留言簿(8)

            隨筆檔案(78)

            搜索

            積分與排名

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            精品视频久久久久| 潮喷大喷水系列无码久久精品 | 亚洲伊人久久成综合人影院 | 99久久这里只精品国产免费| 久久精品国产一区二区电影| 久久久久久极精品久久久 | 国内精品伊人久久久久av一坑| 久久综合精品国产二区无码| 久久婷婷五月综合97色一本一本| 无码精品久久久久久人妻中字| 久久夜色精品国产网站| 91精品久久久久久无码| 日韩欧美亚洲综合久久影院Ds | 99久久婷婷国产综合亚洲| 亚洲欧美日韩精品久久| 亚洲国产成人精品91久久久 | 亚洲国产精品高清久久久| 国产精品国色综合久久| 久久精品国产精品亚洲| 久久精品国产精品亚洲精品 | 精品久久久久久国产三级| 欧美精品丝袜久久久中文字幕| 囯产极品美女高潮无套久久久| 国产成人久久激情91| 欧美午夜A∨大片久久| 麻豆一区二区99久久久久| 7国产欧美日韩综合天堂中文久久久久 | 久久久久亚洲?V成人无码| 97精品国产97久久久久久免费| 嫩草影院久久99| 久久精品无码一区二区无码| 欧美激情精品久久久久久| 久久这里只精品国产99热| 亚洲精品乱码久久久久久 | 狠狠色丁香婷婷久久综合| 国产精品久久毛片完整版| 久久婷婷午色综合夜啪| 久久国产精品波多野结衣AV| 91视频国产91久久久| 亚洲香蕉网久久综合影视| 亚洲国产精品综合久久一线|