棋盘覆盖问题的算法实现

简介: 本文为原创,如需转载,请注明作者和出处,谢谢!    在一个2^k * 2^k个方格组成的棋盘中,有一个方格与其它的不同,若使用以下四种L型骨牌覆盖除这个特殊方格的其它方格,如何覆盖。
本文为原创,如需转载,请注明作者和出处,谢谢!

    在一个2^k * 2^k个方格组成的棋盘中,有一个方格与其它的不同,若使用以下四种L型骨牌覆盖除这个特殊方格的其它方格,如何覆盖。

    四各L型骨牌如下图1



      图1 


棋盘中的特殊方格如图2





图2

    实现的基本原理是将2^k * 2^k的棋盘分成四块2^(k - 1) * 2^(k - 1)的子棋盘,特殊方格一定在其中的一个子棋盘中,如果特殊方格在某一个子棋盘中,继续递归处理这个子棋盘,直到这个子棋盘中只有一个方格为止如果特殊方 格不在某一个子棋盘中,将这个子棋盘中的相应的位置设为骨牌号,将这个无特殊方格的了棋盘转换为有特殊方格的子棋盘,然后再递归处理这个子棋盘。以上原理 如图3所示。





图3

    将棋盘保存在一个二维数组中。骨牌号从1开始,特殊方格为0,如果是一个4 * 4的棋盘,特殊方格为(2,2),那么程序的输出为

2   2   3   3  
2   1   1   3  
4   1   0   5  
4   4   5   5

    
相同数字的为同一骨牌。
下面是棋盘覆盖问题的c语言实现。


#include  < stdio.h >

#define  BOARD_SIZE 4
int  board[BOARD_SIZE][BOARD_SIZE];

//  c1, r1: 棋盘左上角的行号和列号
//  c2, r2: 特殊方格的行号和列号
//  size = 2 ^ k
void  chessboard( int  r1,  int  c1,  int  r2,  int  c2,  int  size)
{
    
if ( 1   ==  size)  return ;
    
int  half_size;
    
static   int  domino_num  =   1 ;
    
int  d  =  domino_num ++ ;
    half_size 
=  size  /   2 ;   
   
    
if (r2  <  r1  +  half_size  &&  c2  <  c1  +  half_size)  // 特殊方格在左上角子棋盘
    {
       chessboard(r1, c1, r2, c2, half_size); 
    }
    
else     //  不在此棋盘,将此棋盘右下角设为相应的骨牌号
    {
       board[r1 
+  half_size  -   1 ][c1  +  half_size  -   1 =  d;
       chessboard(r1, c1, r1 
+  half_size  -   1 , c1  +  half_size  -   1 , half_size);
    }
   
    
if (r2  <  r1  +  half_size  &&  c2  >=  c1  +  half_size)  // 特殊方格在右上角子棋盘
    {
       chessboard(r1, c1 
+  half_size, r2, c2, half_size);
    }
    
else    //  不在此棋盘,将此棋盘左下角设为相应的骨牌号
    {
       board[r1 
+  half_size  -   1 ][c1  +  half_size]  =  d;
       chessboard(r1, c1 
+  half_size, r1  +  half_size  -   1 , c1  +  half_size, half_size);
    }
   
    
if (r2  >=  r1  +  half_size  &&  c2  <  c1  +  half_size)  // 特殊方格在左下角子棋盘
    {
       chessboard(r1 
+  half_size, c1, r2, c2, half_size);
    }
    
else    //  不在此棋盘,将此棋盘右上角设为相应的骨牌号
    {
       board[r1 
+  half_size][c1  +  half_size  -   1 =  d;
       chessboard(r1 
+  half_size, c1, r1  +  half_size, c1  +  half_size  -   1 , half_size);
    }
   
    
if (r2  >=  r1  +  half_size  &&  c2  >=  c1  +  half_size)  // 特殊方格在左上角子棋盘
    {
       chessboard(r1 
+  half_size, c1  +  half_size, r2, c2, half_size);
    }
    
else     //  不在此棋盘,将此棋盘左上角设为相应的骨牌号
    {
       board[r1 
+  half_size][c1  +  half_size]  =  d;
       chessboard(r1 
+  half_size, c1  +  half_size, r1  +  half_size, c1  +  half_size, half_size);
    }   
}

int  main()
{
    
int  i, j;
    board[
2 ][ 2 =   0 ;
    chessboard(
0 0 2 2 , BOARD_SIZE);
    
for (i  =   0 ; i  <  BOARD_SIZE; i ++ )
    {
        
for (j  =   0 ; j  <  BOARD_SIZE; j ++ )
        {
           printf(
" %-4d " , board[i][j]);
        }
        printf(
" /n " );
    }
}



国内最棒的Google Android技术社区(eoeandroid),欢迎访问!

《银河系列原创教程》发布

《Java Web开发速学宝典》出版,欢迎定购

目录
相关文章
|
算法
算法设计与分析/数据结构与算法实验1:棋盘覆盖问题
算法设计与分析/数据结构与算法实验1:棋盘覆盖问题
260 0
算法设计与分析/数据结构与算法实验1:棋盘覆盖问题
|
算法
分治算法——棋盘覆盖
分治算法——棋盘覆盖
181 0
|
算法
【算法竞赛进阶指南】棋盘覆盖(二分图最大匹配)
【算法竞赛进阶指南】棋盘覆盖(二分图最大匹配)
153 0
|
2天前
|
算法 数据安全/隐私保护 计算机视觉
基于Retinex算法的图像去雾matlab仿真
本项目展示了基于Retinex算法的图像去雾技术。完整程序运行效果无水印,使用Matlab2022a开发。核心代码包含详细中文注释和操作步骤视频。Retinex理论由Edwin Land提出,旨在分离图像的光照和反射分量,增强图像对比度、颜色和细节,尤其在雾天条件下表现优异,有效解决图像去雾问题。
|
2天前
|
算法 数据可视化 安全
基于DWA优化算法的机器人路径规划matlab仿真
本项目基于DWA优化算法实现机器人路径规划的MATLAB仿真,适用于动态环境下的自主导航。使用MATLAB2022A版本运行,展示路径规划和预测结果。核心代码通过散点图和轨迹图可视化路径点及预测路径。DWA算法通过定义速度空间、采样候选动作并评估其优劣(目标方向性、障碍物距离、速度一致性),实时调整机器人运动参数,确保安全避障并接近目标。
|
12天前
|
算法 数据安全/隐私保护
室内障碍物射线追踪算法matlab模拟仿真
### 简介 本项目展示了室内障碍物射线追踪算法在无线通信中的应用。通过Matlab 2022a实现,包含完整程序运行效果(无水印),支持增加发射点和室内墙壁设置。核心代码配有详细中文注释及操作视频。该算法基于几何光学原理,模拟信号在复杂室内环境中的传播路径与强度,涵盖场景建模、射线发射、传播及接收点场强计算等步骤,为无线网络规划提供重要依据。
|
13天前
|
机器学习/深度学习 数据采集 算法
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真
本项目基于MATLAB2022a实现时间序列预测,采用CNN-GRU-SAM网络结构。卷积层提取局部特征,GRU层处理长期依赖,自注意力机制捕捉全局特征。完整代码含中文注释和操作视频,运行效果无水印展示。算法通过数据归一化、种群初始化、适应度计算、个体更新等步骤优化网络参数,最终输出预测结果。适用于金融市场、气象预报等领域。
基于GA遗传优化的CNN-GRU-SAM网络时间序列回归预测算法matlab仿真

热门文章

最新文章