我比較傻叉,竟然忘了用動態規劃作,用了遞歸,各類邊界判斷,並且數組稍大一點就棧溢出。遞歸能夠剪支,稍微減小一些遞歸次數。無論怎麼樣仍是貼上本身的傻叉代碼吧ios
#include<iostream> using namespace std; const int M = 10;///列 const int N = 10;///行 int min = N+M; char A[N][M]; ///d=1表明向下走,d=0表明向右走 void f(char A[N][M], int i,int j,int d, int result) { if (i == N-1&&j == M-1) { if (result < min) { min = result; } return; } if (d == 0) ///向右走 { if (j + 1 <= M - 1) ///沒走到邊界 { if (A[i][j + 1] == 'b') ///下一步是障礙物 { f(A, i, j + 1, 0, result + 1); ///清楚障礙物 if (i + 1 <= N - 1) ///走下面 { if (A[i + 1][j] == '0') { f(A, i + 1, j, 1, result); } else { f(A, i + 1, j, 1, result + 1); } } } else { f(A, i, j + 1, 0, result); ///向右走 if (i + 1 <= N - 1) ///向下走 { if (A[i + 1][j] == '0') { f(A, i + 1, j, 1, result + 1); } else { f(A, i + 1, j, 1, result + 2); } } } } else ///已經向右行走到邊界 { ///此處i+1<=N-1,不然應該在遞歸出口 f(A, i + 1, j, 1, result); } } else ////向下行走 { if (i + 1 <= N - 1) ///下邊依舊有路 { if (A[i + 1][j] == 'b') { f(A, i + 1, j, 1, result + 1);///向右繼續走 if (j + 1 <= M - 1) { if (A[i][j + 1] == '0') { f(A, i, j + 1, 0, result); } else { f(A, i, j + 1, 0, result + 1); } } } else { if (j + 1 <= M - 1) { if (A[i][j + 1] == '0') { f(A, i, j + 1, 0, result + 1); } else { f(A, i, j + 1, 0, result + 2); } } f(A, i + 1, j, 1, result); } } else ///已經向下行走到邊界 { f(A, i, j + 1, 0, result); } } } /* int main() { for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { A[i][j] = '0'; } } A[0][4] = 'b'; A[0][5] = 'b'; A[2][5] = 'b'; A[3][3] = 'b'; A[3][4] = 'b'; A[3][5] = 'b'; A[2][6] = 'b'; for (int i = 0; i < N; i++) { for (int j = 0; j < M; j++) { cout << A[i][j] << " "; } cout << endl; } f(A, 0, 0, 0, 0); cout << min << endl; } */