<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆 - 312, 文章 - 14, 評論 - 1393, 引用 - 0
    數據加載中……

    棋盤覆蓋問題的算法實現

    本文為原創,如需轉載,請注明作者和出處,謝謝!

        在一個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(
    0022, BOARD_SIZE);
        
    for(i = 0; i < BOARD_SIZE; i++)
        {
            
    for(j = 0; j < BOARD_SIZE; j++)
            {
               printf(
    "%-4d", board[i][j]);
            }
            printf(
    "\n");
        }
    }





    Android開發完全講義(第2版)(本書版權已輸出到臺灣)

    http://product.dangdang.com/product.aspx?product_id=22741502



    Android高薪之路:Android程序員面試寶典 http://book.360buy.com/10970314.html


    新浪微博:http://t.sina.com.cn/androidguy   昵稱:李寧_Lining

    posted on 2008-05-11 22:29 銀河使者 閱讀(4127) 評論(1)  編輯  收藏 所屬分類: algorithmC/C++ 原創

    評論

    # re: 棋盤覆蓋問題的算法實現  回復  更多評論   

    在vc++2010中驗證該程序,將BOARD_SIZE 變成6,10等就不是完全覆蓋了,不解?(僅驗證這倆數,等于4時候是完全覆蓋)
    2012-11-08 13:09 | jhoon
    主站蜘蛛池模板: 日本久久久免费高清| 最新亚洲春色Av无码专区| 免费无码成人AV片在线在线播放| 久久精品成人免费观看97| 亚洲乱妇熟女爽到高潮的片 | 中文字幕在线观看亚洲| 亚洲毛片不卡av在线播放一区 | 亚洲人成网站18禁止| 亚洲第一中文字幕| 中国亚洲女人69内射少妇| 四虎永久在线精品免费观看地址 | 国产偷国产偷亚洲清高动态图 | 亚洲熟女www一区二区三区| 亚洲专区先锋影音| 精品国产亚洲一区二区三区| 亚洲高清最新av网站| 免费观看国产小粉嫩喷水| 免费鲁丝片一级观看| 久久精品无码一区二区三区免费 | 亚洲精品无码久久久久久久| 亚洲爆乳无码一区二区三区| 国产亚洲精品看片在线观看| 亚洲AV无码一区二三区 | 国产高清视频免费在线观看| 麻豆一区二区三区蜜桃免费| 亚洲AV永久无码精品网站在线观看| 亚洲AV成人无码天堂| 亚洲av成人综合网| 亚洲日本国产综合高清| 67194在线午夜亚洲| 国产99在线|亚洲| 久久久国产亚洲精品| 亚洲成a人片在线观看天堂无码| 亚洲一久久久久久久久| 亚洲精品日韩一区二区小说| 亚洲av无码片vr一区二区三区| 国产精品无码亚洲一区二区三区 | 久久久久一级精品亚洲国产成人综合AV区 | 亚洲精品免费观看| 91网站免费观看| 手机在线毛片免费播放|