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

Uriel's Corner

Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
posts - 0, comments - 50, trackbacks - 0, articles - 594

POJ 1169 Packing Rectangles---模擬

Posted on 2010-08-10 11:57 Uriel 閱讀(517) 評論(0)  編輯 收藏 引用 所屬分類: POJ模擬
        比較麻煩的模擬,倒不是方法難,主要情況多,過程很簡單,就是題目給的那幾種情況枚舉(開始以為隨便放置,所以一直以為是大自然題,所以放了一年沒做。。),題目的case 4 & case 5 可以合并~

        每種case都要考慮橫放和豎放兩種情況,最后一種case還要考慮四個矩形的相對位置。。寫了一晚上+一早上。。代碼很挫。。


#include<stdio.h>
#include
<stdlib.h>
#include
<algorithm>
using namespace std;

#define INF 0x7fffffff

struct Ans{
    
int w,h,area;
}
res[3000];

bool cmp(Ans a,Ans b){
    
if(a.area!=b.area)return a.area<b.area;
    
else
        
return a.w<b.w;
}


int dir[24][4]={{0,1,2,3},{0,1,3,2},{0,2,1,3},{0,2,3,1},{0,3,2,1},{0,3,1,2},
                
{1,2,3,0},{1,2,0,3},{1,0,2,3},{1,0,3,2},{1,3,2,0},{1,3,0,2},
                
{2,0,1,3},{2,0,3,1},{2,1,0,3},{2,1,3,0},{2,3,1,0},{2,3,0,1},
                
{3,0,1,2},{3,0,2,1},{3,1,0,2},{3,1,2,0},{3,2,1,0},{3,2,0,1}}
;
int W,H,n;
int w[5],h[5];

int main(){
    
int i,j,k,tmp,cf;
    
int tw[5],th[5];//case 5 中暫存每個矩形長寬
    int flagw,flagh,flaghh,flagww; //暫存特殊矩形的長寬
    int flag[5]; //case 5 中每個矩形橫放/豎放的情況
    for(i=0;i<4;i++)scanf("%d %d",&w[i],&h[i]);
    n
=0//num of res

    
//-----------------------------------case 1
    
//0->橫放 1->(旋轉180)豎放
    for(i=0;i<16;i++){
        tmp
=i; cf=4;
        H
=0; W=0;
        
while(cf--){
            
if(tmp&1){
                W
+=h[cf]; H=max(w[cf],H);
            }

            
else{
                W
+=w[cf]; H=max(h[cf],H);
            }

            tmp
/=2;
        }
    
//        printf("W=%d H=%d\n",W,H);
        if(W>H)swap(W,H);
        res[n].area
=W*H;
        res[n].w
=W;
        res[n
++].h=H;
    }


    
//-----------------------------------case 2
    
//0->橫放 1->(旋轉180)豎放
    for(i=0;i<4;i++){
        
for(j=0;j<16;j++){
            tmp
=j;cf=4;
            H
=0;W=0;
            
while(cf--){
                
if(cf==i){
                    
if(tmp&1){
                        flagw
=h[cf]; flagh=w[cf];
                    }

                    
else{
                        flagw
=w[cf]; flagh=h[cf];
                    }

                }

                
else{
                    
if(tmp&1){
                        H
=max(H,w[cf]); W+=h[cf];
                    }

                    
else{
                        H
=max(H,h[cf]); W+=w[cf];
                    }

                }

                tmp
/=2;
            }

            H
+=flagh;
            W
=max(W,flagw);
//            printf("W=%d H=%d\n",W,H);
            if(W>H)swap(W,H);
            res[n].area
=W*H;
            res[n].w
=W;
            res[n
++].h=H;
        }

    }


    
//-----------------------------------case 3--------------------WA
    
//0->橫放 1->(旋轉180)豎放
    for(i=0;i<4;i++){
        
for(j=0;j<4;j++){
            
if(i==j)continue;
            
for(k=0;k<16;k++){
                tmp
=k;cf=4;
                W
=0;H=0;
                
while(cf--){
                    
if(cf==i){
                        
if(tmp & 1){
                            flaghh
=w[i]; flagww=h[i];
                        }

                        
else{
                            flaghh
=h[i]; flagww=w[i];
                        }

                    }

                    
else if(cf==j){
                        
if(tmp & 1){
                            flagh
=w[j]; flagw=h[j];
                        }

                        
else{
                            flagh
=h[j]; flagw=w[j];
                        }

                    }

                    
else{
                        
if(tmp & 1){
                            W
+=h[cf]; H=max(H,w[cf]);
                        }

                        
else{
                            W
+=w[cf]; H=max(H,h[cf]);
                        }

                    }

                    tmp
/=2;
                }

                H
=max(flaghh,H+flagh);
                W
=max(W,flagw)+flagww;
//                printf("W=%d H=%d\n",W,H);
                if(W>H)swap(W,H);
                res[n].area
=W*H;
                res[n].w
=W;
                res[n
++].h=H;
            }

        }

    }


    
//-----------------------------------case 4
    
//0->橫放 1->(旋轉180)豎放
    for(i=0;i<4;i++){
        
for(j=0;j<4;j++){
            
if(i==j)continue;
            
for(k=0;k<16;k++){
                tmp
=k;cf=4;
                W
=0;H=0;
                
while(cf--){
//                    printf("cf=%d\n",cf);
                    if(cf==i){
                        
if(tmp & 1){
                            flaghh
=w[i]; flagww=h[i];
                        }

                        
else{
                            flaghh
=h[i]; flagww=w[i];
                        }

                    }

                    
else if(cf==j){
                        
if(tmp & 1){
                            flagh
=w[j]; flagw=h[j];
                        }

                        
else{
                            flagh
=h[j]; flagw=w[j];
                        }

                    }

                    
else{
                        
if(tmp & 1){
                            W
+=h[cf]; H=max(H,w[cf]);
                        }

                        
else{
                            W
+=w[cf]; H=max(H,h[cf]);
                        }

//                        printf("W=%d H=%d\n",W,H);
                    }

                    tmp
/=2;
                }

                H
=max(flaghh+flagh,H);
                W
=max(flagw,flagww)+W;
//                printf("W=%d H=%d\n",W,H);
                if(W>H)swap(W,H);
                res[n].area
=W*H;
                res[n].w
=W;
                res[n
++].h=H;
            }

        }

    }


    
//-----------------------------------case 5
    
//0->橫放 1->(旋轉180)豎放            
    for(i=0;i<16;i++){
        
for(k=0;k<24;k++){
            W
=0;H=0;
            tmp
=i;cf=4;
            
for(j=0;j<4;j++){
                flag[j]
=i&(1<<(j));
                
if(flag[j]){
                    tw[dir[k][j]]
=h[j];
                    th[dir[k][j]]
=w[j];
                }

                
else{
                    tw[dir[k][j]]
=w[j];
                    th[dir[k][j]]
=h[j];
                }

            }

            
if(th[2]>=th[1]+th[3]){
                H
=th[0]+th[2];
                W
=max(max(tw[0],tw[1]+tw[2]),tw[3]+tw[2]);
            }

            
else if(th[2]>th[3&& th[2]<th[1]+th[3]){
                H
=max(th[0]+th[2],th[1]+th[3]);
                W
=max(max(tw[0]+tw[1],tw[1]+tw[2]),tw[2]+tw[3]);
            }

            
else if(th[3]>th[2&& th[3]<th[0]+th[2]){
                W
=max(max(tw[0]+tw[1],tw[0]+tw[3]),tw[2]+tw[3]);
                H
=max(th[0]+th[2],th[1]+th[3]);
            }

            
else if(th[3]>=th[0]+th[2]){
                H
=th[1]+th[3];
                W
=max(max(tw[1],tw[0]+tw[3]),tw[2]+tw[3]);
            }

            
else if(th[2]==th[3]){
                H
=max(th[0]+th[2],th[1]+th[3]);
                W
=max(tw[0]+tw[1],tw[2]+tw[3]);
            }

    
//        printf("W=%d H=%d\n",W,H);
            if(W>H)swap(W,H);
            res[n].area
=W*H;
            res[n].w
=W;
            res[n
++].h=H;
        }

    }

    sort(res,res
+n,cmp);
    printf(
"%d\n",res[0].area);
    printf(
"%d %d\n",res[0].w,res[0].h);
    
int pre=0;
//    printf("\n\n");
    for(i=0;i<n;i++){
        
if(res[i].area==res[0].area && res[i].w!=res[pre].w){
            pre
=i;
            printf(
"%d %d\n",res[i].w,res[i].h);
        }

//        printf("%d %d %d\n",res[i].area,res[i].w,res[i].h);
    }

    
return 0;
}

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲经典在线| 亚洲欧美视频在线| 国产亚洲毛片在线| 久久精品99国产精品日本| 美女诱惑一区| 一本色道久久综合亚洲91| 欧美理论电影网| 久久成人这里只有精品| 亚洲日本电影| 久久国产精品99国产精| 亚洲高清不卡av| 国产日韩av高清| 欧美二区在线看| 亚洲欧美日韩电影| 欧美暴力喷水在线| 欧美一区二区三区免费视频| 亚洲国产精品尤物yw在线观看| 国产精品每日更新在线播放网址| 老牛影视一区二区三区| 午夜精品一区二区三区在线播放| 亚洲精品乱码久久久久久久久| 欧美一区二区视频在线观看| 日韩视频中文字幕| 亚洲福利视频免费观看| 黑人中文字幕一区二区三区| 国产精品入口日韩视频大尺度| 欧美另类69精品久久久久9999| 久久女同精品一区二区| 午夜精品免费视频| 亚洲自拍电影| 亚洲色图自拍| 欧美一区二区免费观在线| 国产欧美成人| 欧美午夜在线| 久久久精彩视频| 欧美国产日本在线| 亚洲网站在线看| 99精品久久| 国产精品国产三级国产aⅴ无密码| 你懂的国产精品| 亚洲激情偷拍| 日韩午夜av在线| 亚洲欧洲一区二区三区| 亚洲国产成人精品视频| 亚洲大胆视频| 国产精品久久久久久久第一福利| 欧美日韩精品一区| 欧美日韩一区三区| 欧美午夜精品久久久久久人妖| 欧美三级电影网| 国产麻豆日韩| 性欧美长视频| 亚洲精品国产系列| 亚洲一区二区三区乱码aⅴ| 宅男噜噜噜66一区二区66| 亚洲一区二区免费看| 亚洲免费在线精品一区| 亚洲第一页中文字幕| 激情另类综合| 亚洲级视频在线观看免费1级| 亚洲精品国产欧美| 欧美日韩另类一区| 国产日韩精品一区二区三区在线| 国产精品自拍三区| 精久久久久久| 在线亚洲一区观看| 久久久久国色av免费观看性色| 欧美xx视频| 99re热这里只有精品免费视频| 最新国产の精品合集bt伙计| 99re6这里只有精品| 欧美怡红院视频| 欧美激情第9页| 亚洲欧美日韩国产| 嫩草国产精品入口| 国产欧美精品一区二区三区介绍| 亚洲国产日韩欧美在线图片| 亚洲一区二区三| 在线一区日本视频| 久久久久久亚洲精品中文字幕| 亚洲大胆在线| 午夜精品久久久久久久| 老司机免费视频一区二区| 日韩午夜电影| 女同性一区二区三区人了人一| 国产精品一区二区久久国产| 最新国产乱人伦偷精品免费网站| 午夜视频一区二区| 亚洲精品国精品久久99热| 久久久999精品| 国产精品久久久久毛片大屁完整版 | 黄色av成人| 一本色道久久综合亚洲二区三区 | 在线看片成人| 亚洲性视频h| 欧美激情视频免费观看| 久久国产免费看| 国产精品一区免费观看| 一本大道久久a久久综合婷婷| 久久一区二区视频| 欧美亚洲视频一区二区| 国产精品ⅴa在线观看h| 日韩午夜高潮| 亚洲国产三级| 欧美大片免费看| 在线观看日韩专区| 噜噜噜在线观看免费视频日韩| 欧美va亚洲va香蕉在线| 亚洲乱码国产乱码精品精| 欧美大片在线看| 久久精品国产一区二区电影| 国产精品一区久久| 欧美中文字幕在线观看| 小辣椒精品导航| 国产欧美日韩伦理| 欧美综合国产| 午夜精彩国产免费不卡不顿大片| 国产精品jvid在线观看蜜臀| 亚洲午夜羞羞片| 亚洲一区影音先锋| 久久人人看视频| 亚洲国产成人91精品| 亚洲电影在线免费观看| 亚洲一区网站| 国产伦精品一区二区三区视频黑人 | 久久在线精品| 亚洲黄色在线观看| 亚洲精品视频在线看| 国产精品av免费在线观看| 亚洲欧美激情一区| 久久成人精品一区二区三区| 狠狠色噜噜狠狠狠狠色吗综合| 裸体歌舞表演一区二区| 久久人体大胆视频| 日韩香蕉视频| 亚洲欧美精品中文字幕在线| 国产一区 二区 三区一级| 女女同性精品视频| 欧美激情精品久久久久久大尺度 | 欧美激情一区二区三区蜜桃视频| 亚洲二区免费| 亚洲人在线视频| 国产精品久久久一区麻豆最新章节| 欧美与黑人午夜性猛交久久久| 欧美一区二区三区在线观看视频| 欧美成人影音| 亚洲男女自偷自拍图片另类| 欧美一区亚洲| 亚洲伦理网站| 亚洲欧美日韩在线高清直播| 亚洲二区三区四区| 亚洲免费在线观看视频| 亚洲福利视频网| 先锋影音久久久| 夜夜嗨av一区二区三区免费区| 久久婷婷国产综合精品青草| 一区二区三区视频在线看| 韩国精品在线观看| 久久精品首页| 欧美久久99| 久久综合导航| 国产精一区二区三区| 亚洲第一区在线观看| 国产日韩精品视频一区| 欧美成人激情视频免费观看| 亚洲一区二区三区激情| 久久久精品一区| 亚洲风情在线资源站| 亚洲精品一二三区| 国产精品成人一区二区三区夜夜夜 | 小黄鸭精品密入口导航| 女仆av观看一区| 亚洲精一区二区三区| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲欧美日韩综合| 欧美激情精品久久久久久变态| 亚洲一区二区三区视频| 红桃视频一区| 欧美日韩dvd在线观看| 午夜欧美不卡精品aaaaa| 欧美激情一区二区三区高清视频| 亚洲天堂激情| 在线日韩av片| 国产精品手机视频| 欧美成人一区在线| 午夜精品视频在线| 亚洲欧洲中文日韩久久av乱码| 香港久久久电影| 亚洲精品久久在线| 好吊一区二区三区| 国产精品一区二区三区乱码| 欧美日韩国产系列| 欧美a级在线| 久久久av毛片精品| 亚洲天堂久久| 亚洲美女色禁图| 亚洲国产精品传媒在线观看 | 久久久久久一区| 免费黄网站欧美| 亚洲午夜精品一区二区|