一、实验目的与要求
1、掌握棋盘覆盖问题的算法;
2、初步掌握分治算法
二、实验题:
盘覆盖问题:在一个2k×2k 个方格组成的棋盘中,恰有一个方格与其它方格不同,称该方格为一特殊方格,且称该棋盘为一特殊棋盘。在棋盘覆盖问题中,要用图示的4种不同形态的L型骨牌覆盖给定的特殊棋盘上除特殊方格以外的所有方格,且任何2个L型骨牌不得重叠覆盖。
参考输入、输出:
输入:输入第一行包括一个整数k,第二行两个整数x,y代表特殊点坐标(从1开始)。
输出:输出一个2k×2k的矩阵代表结果,0表示特殊点。
Simple input:
2
1 2
Simple output:
2 0 3 3
2 2 1 3
4 1 1 5
4 4 5 5
三、实现思想
方阵的边数为2^n,将方阵四等分,在其中一个等分块中加入一个特殊方块,在分割线处标记L型骨,使缺口对着有着特殊方块的等分块。
四、实现代码
#include<bits/stdc++.h>
using namespace std;
int title=1,a[100][100];
void chessboard(int tr,int tc,int dr,int dc,int size)
{
if(size==1)
return;
int s=size/2;
int t=title++;
if(dr<tr+s&&dc<tc+s)
chessboard(tr,tc,dr,dc,s);
else
{
a[tr+s-1][tc+s-1]=t;
chessboard(tr,tc,tr+s-1,tc+s-1,s);
}
if(dr<tr+s&&dc>=tc+s)
chessboard(tr,tc+s,dr,dc,s);
else
{
a[tr+s-1][tc+s]=t;
chessboard(tr,tc+s,tr+s-1,tc+s,s);
}
if(dr>=tr+s&&dc<tc+s)
chessboard(tr+s,tc,dr,dc,s);
else
{
a[tr+s][tc+s-1]=t;
chessboard(tr+s,tc,tr+s,tc+s-1,s);
}
if(dr>=tr+s&&dc>=tc+s)
chessboard(tr+s,tc+s,dr,dc,s);
else
{
a[tr+s][tc+s]=t;
chessboard(tr+s,tc+s,tr+s,tc+s,s);
}
}
int main()
{
int m,n,k;
cin>>k;
for(int i=1;i<=pow(2,k);i++)
for(int j=1;j<=pow(2,k);j++)
a[i][j]=-1;
cin>>m>>n;
a[m][n]=0;
chessboard(1,1,m,n,pow(2,k));
for(int i=1;i<=pow(2,k);i++)
{for(int j=1;j<=pow(2,k);j++)
printf("%2d ",a[i][j]);
cout<<endl;
}
}
五、实验结果