| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 726 人关注过本帖, 1 人收藏
标题:老鼠走迷宫问题求有--程序,只求解说,谢谢
只看楼主 加入收藏
lhf289021706
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2013-9-29
结帖率:100%
收藏(1)
已结贴  问题点数:20 回复次数:5 
老鼠走迷宫问题求有--程序,只求解说,谢谢
6.Algorithm Gossip: 老鼠走迷官(二)
说明由于迷宫的设计,老鼠走迷宫的入口至出口路径可能不只一条,如何求出所有的路径呢?
解法求所有路径看起来复杂但其实更简单,只要在老鼠走至出口时显示经过的路径,然后退回上一格重新选择下一个位置继续递回就可以了,比求出单一路径还简单,我们的程式只要作一点修改就可以了。

//这是原题,我看不懂得地方是  visit 函数 这是怎么回事啊。。。。。。

#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;

 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);         
}
搜索更多相关主题的帖子: include visit 老鼠 如何 
2013-09-30 11:33
qunxingw
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:24
帖 子:1676
专家分:7295
注 册:2011-6-30
收藏
得分:9 
从左上顶往右或往下递归找出口

www.qunxingw.wang
2013-09-30 12:30
lhf289021706
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2013-9-29
收藏
得分:0 
回复 2楼 qunxingw
你说的对,可是,那个函数,他是int类型,应该有返回值,他是返回一个过程吗?还是返回一个值
2013-09-30 12:47
yuccn
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:何方
等 级:版主
威 望:167
帖 子:6815
专家分:42393
注 册:2010-12-16
收藏
得分:0 
以下是引用lhf289021706在2013-9-30 12:47:55的发言:

你说的对,可是,那个函数,他是int类型,应该有返回值,他是返回一个过程吗?还是返回一个值


写漏了吧

我行我乐
公众号:逻辑客栈
我的博客:
https://blog.yuccn. net
2013-09-30 13:43
lhf289021706
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2013-9-29
收藏
得分:0 
回复 4楼 yuccn
拜托,没有写漏啊,你运行看看,它是怎样实现的,我也不懂,我都一一把数据对过,认真分析它的实现过程,可还是不懂啊。。。。。。。
2013-10-01 09:26
husiwen
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
威 望:2
帖 子:227
专家分:1125
注 册:2010-5-23
收藏
得分:11 
回复 5楼 lhf289021706
要return success 和success=1写一起
2013-10-02 10:57
快速回复:老鼠走迷宫问题求有--程序,只求解说,谢谢
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016428 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved