| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 447 人关注过本帖
标题:马的遍历——这到底是怎么回事???
只看楼主 加入收藏
c4fun
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2012-8-6
结帖率:0
收藏
已结贴  问题点数:40 回复次数:3 
马的遍历——这到底是怎么回事???
程序代码:
#include <stdio.h>
#define N 8
int moveX[]={-2,-1,1,2,2,1,-1,-2};
int moveY[]={1,2,2,1,-1,-2,-2,-1};
int board[N][N];

int next(int r,int c,int array[N][N],int step)
{
    int tempX,tempY,i;
    if(step==N*N)
        return 0;
    step++;

    for(i=0;i<8;i++)
    {
        tempX=r+moveX[i];
        tempY=c+moveY[i];
        if(tempX>=0 && tempX <N && tempY>=0 && tempY<N && array[tempX][tempY]==0)
        {
            array[tempX][tempY]=step;//-------- 
            if(! next(tempX,tempY,array,step))
                return 0;
        }
    }
    return 1;
}

int main()
{
    int startX,startY,i,j;
    printf("input coordinate of the first node:x and y\n");
    scanf("%d%d",&startX,&startY);

    board[startX][startY]=1;
    next(startX,startY,board,1);

    for(i=0;i<N;i++)
    {
        for(j=0;j<N;j++)
            printf("%-4d",board[i][j]);
        printf("\n\n");
    }

    return 0;
}

希望大家帮我看一下,谢谢!

[ 本帖最后由 c4fun 于 2013-6-20 10:49 编辑 ]
搜索更多相关主题的帖子: color 
2013-06-20 10:36
c4fun
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2012-8-6
收藏
得分:0 
这是程序运行截图:
图片附件: 游客没有浏览图片的权限,请 登录注册
2013-06-20 10:39
c4fun
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2012-8-6
收藏
得分:0 
大家发表一下看法吧,衷心感谢啦
2013-06-20 10:45
你不想去那儿
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:56
专家分:114
注 册:2012-9-21
收藏
得分:40 
你这个是从38开始错的!
38->39->40,无法遍历到41
递归开始返回,直到38,38又遍历到一个新的39位置
从这之后全部错误!
2013-06-22 00:00
快速回复:马的遍历——这到底是怎么回事???
数据加载中...
 
   



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

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