算法java实现--分治法--棋盘覆盖问题

棋盘覆盖问题的java实现(分治法)

具体问题描述以及C/C++实现参见网址

http://blog.csdn.net/liufeng_king/article/details/8477868

/**
 * 棋盘覆盖问题--分治法
 */
public class Qipanfugai {
	public int tile = 1;
	public int[][] board;//整型数组保存棋盘
	public Qipanfugai(int size){
		board = new int[size][size];
		/*A a=new B();
                        是否可以解释为:声明了一个A类名叫a,为它开辟了一块内存空间B并保存在B中!*/
        /*对象的成员变量初始化。在对象的初始化过程中,基本数据类型(例如int,char,byte等)都会有默认值,比如int类型的成员变量的默认值为0;但非基本数据类型的其他对象类型则默认值为Null,例如String类型的默认值为null,Date类型的默认值也是null。*/
	}
	/**
	 * 实现棋盘覆盖的分枝法
	 * @param tr棋盘左上角行号(从0开始)
	 * @param tc棋盘左上角列号
	 * @param dr特殊方格行号
	 * @param dc特殊方格列号
	 * @param size棋盘规格(size*size)
	 */
	public void chessBoard(int tr,int tc,int dr,int dc,int size){

		if(size==1)return;
		int t = tile;
		tile++;
		int s=size/2;
		//左上角
		if(dr=tc+s){
			chessBoard(tr,tc+s,dr,dc,s);
		}else{
			board[tr+s-1][tc+s]=t;
			chessBoard(tr,tc+s,tr+s-1,tc+s,s);
		}
		//左下角
		if(dr>=tr+s&&dc=tr+s&&dc>=tc+s){
			chessBoard(tr+s,tc+s,dr,dc,s);
		}else{
			board[tr+s][tc+s]=t;
			chessBoard(tr+s,tc+s,tr+s,tc+s,s);
		}
	}
	public static void main(String[] args) {
//		Qipanfugai qi = new Qipanfugai(4);
//		qi.chessBoard(0, 0, 0, 1, 4);
		
		Qipanfugai qi = new Qipanfugai(8);
		qi.chessBoard(0, 0, 7, 4, 8);
		for(int i = 0;i


你可能感兴趣的:(java算法)