微軟筆試題,機器人消磚塊

我比較傻叉,竟然忘了用動態規劃作,用了遞歸,各類邊界判斷,並且數組稍大一點就棧溢出。遞歸能夠剪支,稍微減小一些遞歸次數。無論怎麼樣仍是貼上本身的傻叉代碼吧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;
}
*/
相關文章
相關標籤/搜索