无码av一区二区三区无码,在线观看老湿视频福利,日韩经典三级片,成 人色 网 站 欧美大片在线观看

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

P1228_地毯填補(bǔ)問題-遞歸構(gòu)造應(yīng)用

2023-01-16 11:16 作者:信奧賽USACO鄭老師  | 我要投稿

#include<bits/stdc++.h>

using namespace std;


struct point{

int x,y;

};

//*****

//*1*2*

//*****

//*3*4*

//*****

//----->y

//|

//|

//x

int split(point bl, int n, point blank){

int dir=0;

if(blank.x<bl.x+n/2){

if(blank.y<bl.y+n/2){

dir=1;//blank cell in sec 1

}else{

dir=2;//sec 2

}

}else{

if(blank.y<bl.y+n/2){

dir=3;//sec 3

}else{

dir=4;//sec 4

}

}

switch(dir){

case 1://blank cell in sec 1

cout<<bl.x+n/2<<" "<<bl.y+n/2<<" "<<1<<endl;

if(n>2){//recusively

split({bl.x,bl.y},n/2,blank);//for sec 1

split({bl.x,bl.y+n/2},n/2,{bl.x+n/2-1,bl.y+n/2});//for sec 2

split({bl.x+n/2,bl.y},n/2,{bl.x+n/2,bl.y+n/2-1});//for sec 3

split({bl.x+n/2,bl.y+n/2},n/2,{bl.x+n/2,bl.y+n/2});//for sec 4

}

break;

case 2://blank cell in sec 2

cout<<bl.x+n/2<<" "<<bl.y+n/2-1<<" "<<2<<endl;

if(n>2){

split({bl.x,bl.y},n/2,{bl.x+n/2-1,bl.y+n/2-1});//for sec 1

split({bl.x,bl.y+n/2},n/2,blank);//for sec 2

split({bl.x+n/2,bl.y},n/2,{bl.x+n/2,bl.y+n/2-1});//for sec 3

split({bl.x+n/2,bl.y+n/2},n/2,{bl.x+n/2,bl.y+n/2});//for sec 4

}

break;

case 3://blank cell in sec 3

cout<<bl.x+n/2-1<<" "<<bl.y+n/2<<" "<<3<<endl;

if(n>2){

split({bl.x,bl.y},n/2,{bl.x+n/2-1,bl.y+n/2-1});//for sec 1

split({bl.x,bl.y+n/2},n/2,{bl.x+n/2-1,bl.y+n/2});//for sec 2

split({bl.x+n/2,bl.y},n/2,blank);//for sec 3

split({bl.x+n/2,bl.y+n/2},n/2,{bl.x+n/2,bl.y+n/2});//for sec 4

}

break;

case 4://blank cell in sec 4

cout<<bl.x+n/2-1<<" "<<bl.y+n/2-1<<" "<<4<<endl;

if(n>2){

split({bl.x,bl.y},n/2,{bl.x+n/2-1,bl.y+n/2-1});//for sec 1

split({bl.x,bl.y+n/2},n/2,{bl.x+n/2-1,bl.y+n/2});//for sec 2

split({bl.x+n/2,bl.y},n/2,{bl.x+n/2,bl.y+n/2-1});//for sec 3

split({bl.x+n/2,bl.y+n/2},n/2,blank);//for sec 4

}

break;

}

return 0;

}

int main(){

int k,x,y;

cin>>k;

cin>>x>>y;

int n=1;

n=n<<k;

split({1,1},n,{x,y});

return 0;

}


P1228_地毯填補(bǔ)問題-遞歸構(gòu)造應(yīng)用的評論 (共 條)

分享到微博請遵守國家法律
梅河口市| 合水县| 邳州市| 海口市| 汝阳县| 中西区| 离岛区| 东乡族自治县| 长治市| 易门县| 东兰县| 伊金霍洛旗| 柞水县| 凤台县| 金川县| 沽源县| 三亚市| 临高县| 佛山市| 那曲县| 大石桥市| 望都县| 咸阳市| 扶风县| 张北县| 丰原市| 桦川县| 武义县| 大姚县| 长海县| 石门县| 兴安盟| 邵武市| 通化市| 南通市| 曲阜市| 南皮县| 满洲里市| 阿尔山市| 娄底市| 柳林县|