最美情侣中文字幕电影,在线麻豆精品传媒,在线网站高清黄,久久黄色视频

歡迎光臨散文網(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)用的評論 (共 條)

分享到微博請遵守國家法律
平湖市| 罗山县| 绥滨县| 宜昌市| 彝良县| 盐津县| 新野县| 延安市| 庆阳市| 禄丰县| 东至县| 泰兴市| 濮阳县| 连南| 凤台县| 安多县| 九台市| 藁城市| 莱州市| 色达县| 新营市| 西乡县| 杭锦后旗| 五大连池市| 内黄县| 驻马店市| 龙山县| 余江县| 栾城县| 阆中市| 邯郸市| 广安市| 武陟县| 南宁市| 乃东县| 商城县| 攀枝花市| 曲沃县| 民县| 祁东县| 磐石市|