java迷宫鼠_老鼠走迷宫算法 迷宫回溯算法 c语言算法

[c]代码库#include

#include

int visit ( int, int );

int maze[7][7] = {{2, 2, 2, 2, 2, 2, 2},

{2, 0, 0, 0, 0, 0, 2},

{2, 0, 2, 0, 2, 0, 2},

{2, 0, 0, 2, 0, 2, 2},

{2, 2, 0, 2, 0, 2, 2},

{2, 0, 0, 0, 0, 0, 2},

{2, 2, 2, 2, 2, 2, 2}

};

int startI = 1, startJ = 1; // 入口

int endI = 5, endJ = 5; // 出口

int success = 0;

int main ( void )

{

int i, j;

printf ( "显示迷宫:\n" );

for ( i = 0; i < 7; i++ )

{

for ( j = 0; j < 7; j++ )

if ( maze[i][j] == 2 )

printf ( "█" );

else

printf ( " " );

printf ( "\n" );

}

if ( visit ( startI, startJ ) == 0 )

printf ( "\n没有找到出口!\n" );

else

{

printf ( "\n显示路径:\n" );

for ( i = 0; i < 7; i++ )

{

for ( j = 0; j < 7; j++ )

{

if ( maze[i][j] == 2 )

printf ( "█" );

else if ( maze[i][j] == 1 )

printf ( "◇" );

else

printf ( " " );

}

printf ( "\n" );

}

}

return 0;

}

int visit ( int i, int j )

{

maze[i][j] = 1;

if ( i == endI && j == endJ )

success = 1;

if ( success != 1 && maze[i][j+1] == 0 ) visit ( i, j+1 );

if ( success != 1 && maze[i+1][j] == 0 ) visit ( i+1, j );

if ( success != 1 && maze[i][j-1] == 0 ) visit ( i, j-1 );

if ( success != 1 && maze[i-1][j] == 0 ) visit ( i-1, j );

if ( success != 1 )

maze[i][j] = 0;

return success;

}

[代码运行效果截图]

8928d3c0512b03776eacb5bb450e75c4.png

694748ed64b9390909c0d88230893790.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值