• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

c语言 海叔叔 4年前 (2021-11-15) 73次浏览 已收录 0个评论

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

#include <stdio.h>
#include <stdlib.h>
 
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;
}


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:老鼠走迷宫算法 迷宫回溯算法 c语言算法
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址