| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 504 人关注过本帖
标题:帮忙看看,为什么没输出
只看楼主 加入收藏
枫叶无痕
Rank: 2
等 级:论坛游民
帖 子:80
专家分:30
注 册:2011-2-10
结帖率:73.91%
收藏
已结贴  问题点数:20 回复次数:9 
帮忙看看,为什么没输出
#include<stdio.h>
#include<string.h>
int dir[8][2]={{2,1},{1,2},{-1,2},{-2,1},{1,-2},{2,-1},{-1,-2},{-2,-1}};
int count;
int n,m;
void bfs(int x,int y)
{
    int xx,yy;
    int i;
    for(i=0;i<8;i++)
    {
        xx=x+dir[i][0];
        yy=y+dir[i][1];
        if(xx>5||xx<=0||yy>4||yy<=0)
        continue;
        if(xx==n&&yy==m)
        {
            count++;
            continue;
        }
        bfs(xx,yy);
    }
}
int main()
{
    scanf("%d%d",&n,&m);
    count=0;
    bfs(n,m);
    printf("%d\n",count);
    return 0;
}
搜索更多相关主题的帖子: void continue include count 
2011-08-14 14:43
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:5 
你检查一下,运行中m、n到底是什么值?

授人以渔,不授人以鱼。
2011-08-14 14:46
hjywyj
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:3
帖 子:1114
专家分:2611
注 册:2010-4-14
收藏
得分:5 
你这个程序要干啥?
2011-08-14 14:51
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:5 
这个是很典型的了,
scanf("%d%d",&n,&m);
你教一教scanf()函数,它怎么区分你输入的一连串字符是哪两个整数?比如,"12345",它认为是12、345,还是123、45好呢?又假如你输入的是"12,345",它没预期你使用逗号啊,你又没在第一个参数的格式串中告诉你将使用逗号,它会把逗号当整数读入的。

说到底,scanf()和printf()是一种语言解释器,是用C编的简陋BASIC,它是解释执行的机制,这个本质一定要搞清楚。

授人以渔,不授人以鱼。
2011-08-14 14:54
枫叶无痕
Rank: 2
等 级:论坛游民
帖 子:80
专家分:30
注 册:2011-2-10
收藏
得分:0 
回复 2楼 TonyDeng
再帮忙看一下,这题目还要考虑什么?

马的走法

Time Limit:1000MS  Memory Limit:65536K
Total Submit:174 Accepted:104

Description

在一个4*5的棋盘上,输入马的起始位置坐标(纵、横),求马能返回初始位置的所有不同走法的总数(马走过的位置不能重复,马走“日”字)。

Input

多个测试数据。
每组2个数字

Output

输出不同走法的总数。

Sample Input


2 2
Sample Output


4596
Source


#include<stdio.h>
#include<string.h>
int dir[8][2]={{2,1},{1,2},{-1,2},{-2,1},{1,-2},{2,-1},{-1,-2},{-2,-1}};
int count;
int n,m;
int map[6][7];
void bfs(int x,int y)
{
    int xx,yy;
    int i;
    for(i=0;i<8;i++)
    {
        xx=x+dir[i][0];
        yy=y+dir[i][1];
        if(xx>5||xx<=0||yy>4||yy<=0)
        continue;
        if(map[xx][yy])
        continue;
        if(xx==n&&yy==m)
        {
            count++;
            continue;
        }
        map[xx][yy]=1;
        bfs(xx,yy);
        map[xx][yy]=0;
    }
}
int main()
{
    while(scanf("%d%d",&n,&m)!=EOF)
    {count=0;
    memset(map,0,sizeof(map));
    bfs(n,m);
    printf("%d\n",count);}
    return 0;
}
2011-08-14 15:00
QQ346957135
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:148
专家分:658
注 册:2011-8-9
收藏
得分:5 
楼主想干什么,请说清楚,这样搞得人一头雾水

A real warrior never quits.
2011-08-14 15:02
QQ346957135
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:148
专家分:658
注 册:2011-8-9
收藏
得分:0 
哦,知道了

A real warrior never quits.
2011-08-14 15:03
枫叶无痕
Rank: 2
等 级:论坛游民
帖 子:80
专家分:30
注 册:2011-2-10
收藏
得分:0 
明白了,谢谢大家了,原来是横坐标和纵坐标搞错了。谢谢了
2011-08-14 15:05
TonyDeng
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:贵宾
威 望:304
帖 子:25859
专家分:48889
注 册:2011-6-22
收藏
得分:0 
走马的算法,这里很多专学相关算法的人比我熟悉,我还真不弄这类程序,这方面没建议。我只是很大程度上怀疑你上面没输出是输入错误所致。

授人以渔,不授人以鱼。
2011-08-14 15:05
QQ346957135
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:148
专家分:658
注 册:2011-8-9
收藏
得分:0 
回复 7楼 QQ346957135
麻烦楼主教我一下,这程序我不太懂

A real warrior never quits.
2011-08-14 15:08
快速回复:帮忙看看,为什么没输出
数据加载中...
 
   



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

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