這個是我做 kuangbin 帶你飛專題訓練的第乙個專題的第一題
在乙個給定形狀的棋盤(形狀可能是不規則的)上面擺放棋子,棋子沒有區別。要求擺放時任意的兩個棋子不能放在棋盤中的同一行或者同一列,求解對於給定形狀和大小的棋盤,擺放k個棋子的所有可行的擺放方案c。
==其中 # 表示棋盤區域, . 表示空白區域(資料保證不出現多餘的空白行或者空白列)。 ==
這是一道經典的深搜問題。
dfs函式只有乙個形參,那就是行數,因為題目中說了兩個棋子不能放在乙個棋盤的同一行或同一列,所以,一行只能選乙個能放棋子的位置來放棋子。首先定義乙個陣列a用來記錄第j列是否有棋子放入.
注意 是第j列
然後定義乙個全域性變數num來記錄已經往棋盤中放入了多少個棋子了,遞迴的邊界條件就是num等於k.
#include using namespace std;
int a[10];
char chess[10][10];//定義棋盤
int flag=0;//flag代表擺放棋盤的方案數
int num=0;//num代表選擇放入棋子的個數
int n,k;
void dfs(int r) //r代表行數
if(r >= n) return;//當搜尋的行數大於棋盤時,直接返回(判斷邊界)。
for(int j = 0;j < n; j++)//在r行從第乙個位置開始例舉
}dfs(r+1);//該行已經有棋子,深搜下一行。
}int main(){
while(cin>>n>>k&&n != -1&&k != -1)
{for(int i = 0; i < n; i++)
for(int j = 0 ; j < n; j++)
cin>>chess[i][j];
flag = num = 0;//別忘記每次都要初始化,這是多樣例題。
dfs(0);//從第一行開始深搜。
cout 在乙個給定形狀的棋盤 形狀可能是不規則的 上面擺放棋子,棋子沒有區別。要求擺放時任意的兩個棋子不能放在棋盤中的同一行或者同一列,請程式設計求解對於給定形狀和大小的棋盤,擺放k個棋子的所有可行的擺放方案c。input 輸入含有多組測試資料。每組資料的第一行是兩個正整數,n k,用乙個空格隔開,表示了將... 總時間限制 1000ms 記憶體限制 65536kb 描述 在乙個給定形狀的棋盤 形狀可能是不規則的 上面擺放棋子,棋子沒有區別。要求擺放時任意的兩個棋子不能放在棋盤中的同一行或者同一列,請程式設計求解對於給定形狀和大小的棋盤,擺放k個棋子的所有可行的擺放方案c。輸入輸入含有多組測試資料。每組資料的... poj1321 dfs 棋盤問題 解題報告 1.題意很簡單,乙個棋盤問題,可以用搜尋方式解決。那麼好,它的搜尋框架很明晰了,從乙個狀態到下乙個搜尋狀態,直到數目達到k,計數加一,或者此搜尋狀態無解,回溯。顯然,搜尋退出條件是數目達到k或者此搜尋狀態無解。2.狀態如何表示?vis i j 標記是否有落...簡單搜尋 棋盤問題
簡單搜尋(一)之 棋盤問題
棋盤問題 簡單搜尋練習