每日一算法:老鼠走迷官(二)

说明由于迷宫的设计,老鼠走迷宫的入口至出口路径可能不只一条,如何求出所有的路径呢?

解法求所有路径看起来复杂但其实更简单,只要在老鼠走至出口时显示经过的路径,然后退回上一格重新选择下一个位置继续回溯就可以了,比求出单一路径还简单,我们的程式只要作一点修改就可以了。

#include <stdio.h>

void visit(int, int);
int maze[9][9] = {
	{2, 2, 2, 2, 2, 2, 2, 2, 2},
	{2, 0, 0, 0, 0, 0, 0, 0, 2},
	{2, 0, 2, 2, 0, 2, 2, 0, 2},
	{2, 0, 2, 0, 0, 2, 0, 0, 2},
	{2, 0, 2, 0, 2, 0, 2, 0, 2},
	{2, 0, 0, 0, 0, 0, 2, 0, 2},
	{2, 2, 0, 2, 2, 0, 2, 2, 2},
	{2, 0, 0, 0, 0, 0, 0, 0, 2},
	{2, 2, 2, 2, 2, 2, 2, 2, 2}};
	
	int startI = 1, startJ = 1;  // 入口
	int endI = 7, endJ = 7;  // 出口
	
	int main(void) 
	{ 
		int i, j; 
		printf("显示迷宫:\n"); 
		for(i = 0; i < 9; i++)
		{ 
			for(j = 0; j < 9; j++)
			{
				if(maze[i][j] == 2) 
				{
					printf("█"); 
				}
				else 
				{
					printf("  ");
				}
			}
			printf("\n"); 
	} 
	visit(startI, startJ);
	return 0; 
} 
void visit(int i, int j)
 {
	int m, n;
	maze[i][j] = 1; 
	if(i == endI && j == endJ)
	{
		printf("\n显示路径:\n");
		for(m = 0; m < 9; m++)
		{
			for(n = 0; n < 9; n++)
			{
				if(maze[m][n] == 2)
				{
					printf("█");
				}
				else if(maze[m][n] == 1)
				{
					printf("◇");
				}
				else
				{
					printf("  ");
				}
			}
			printf("\n");
		
		}
	}
	if(maze[i][j+1] == 0)
	{
		visit(i, j+1);
	}
	if(maze[i+1][j] == 0) 
	{
		visit(i+1, j);
	}
	if(maze[i][j-1] == 0) 
	{
		visit(i, j-1);
	}

	if(maze[i-1][j] == 0)
	{
		visit(i-1, j);
	}
	maze[i][j] = 0;
	
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值