棋盘问题利用分治思想将子问题与原问题的问题类型一样但是让子问题的规模不断缩小,直到很容易求出直接求出解。
当问题规模为n时可以将方块分解为规模为2的规模
#include <stdio.h>
const int N=8;//N的值必须为2^k,如1、2、4、8、16
int qipan[N][N];
int number=0;
void chessBoard(int row,int column,int x,int y,int size)//棋盘起始方格下标(左上角),特殊方格下标,棋盘大小size*size
{
if(size==1) return;
int s=size/2;
int t=++number;
int centerR=row+s;
int centerC=column+s;
if(x

本文探讨如何运用分治算法解决棋盘问题,通过不断缩小问题规模至基础情况,逐步得出最终解。
最低0.47元/天 解锁文章
1116

被折叠的 条评论
为什么被折叠?



