一条回溯题,思路有了,调试通不过啊…… - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
publicID123
V2EX    问与答

一条回溯题,思路有了,调试通不过啊……

  •  
  •   publicID123 2014 年 10 月 24 日 via iPad 2931 次点击
    这是一个创建于 4120 天前的主题,其中的信息可能已经有所发展或是发生改变。
    题目:
    描述

    棋盘上A点有一个过河卒,需要走到目标B点。卒行走的规则:可以向下、或者向右。同时在棋盘上C点有一个对方的马,该马所在的点和所有跳跃一步可达的点称为对方马的控制点。因此称之为“马拦过河卒”。

    棋盘用坐标表示,A点(0, 0)、B点(n, m)(n, m为不超过15的整数),同样马的位置坐标是需要给出的。现在要求你计算出卒从A点能够到达B点的路径的条数,假设马的位置是固定不动的,并不是卒走一步马走一步。

    输入

    一行四个数据,分别表示B点坐标和马的坐标。

    输出

    一个数据,表示所有的路径条数。

    样例输入

    6 6 3 3

    样例输出

    6

    思路:
    开一个二维数组表示所有点的情况,马可以达到的点飙为 false 。

    只要卒和开始给的点重合就计数。

    感觉思路没错,但是就是调试不对啊,求大牛帮看看代码到底错在哪里了。

    代码:
    8 条回复    2014-10-25 20:58:50 +08:00
    z7059652
        1
    z7059652  
       2014 年 10 月 24 日
    回溯法的回溯之处 你有吗?
    xjx0524
        2
    xjx0524  
       2014 年 10 月 25 日 via Android
    卒的起点是0,0啊,你从马踩的位置搜干什么
    再说这题递推就行不用搜索啊
    stackpop
        3
    stackpop  
       2014 年 10 月 25 日
    首先,把回溯法的概念搞清楚。

    其次,建议楼主学一下 DFS, BFS
    msg7086
        4
    msg7086  
       2014 年 10 月 25 日
    我只指出其中一个错误。

    if(map[x][y]=false)
    msg7086
        5
    msg7086  
       2014 年 10 月 25 日
    第二个错误你自己思考吧,不难。我已经调通了,应该是没有错的。

    $ ./horse
    6 6 3 3
    6
    $ ./horse
    10 10 4 4
    6802
    randomize
        6
    randomize  
       2014 年 10 月 25 日 via iPad
    @msg7086
    感谢。Accepted .

    剩余的一处错误是马自己的位置也是不能走的,而不仅仅是它能到的位置。

    另外,顺带问下大大……我这么写算什么?真的不是传说中的回溯么……
    randomize
        7
    randomize  
       2014 年 10 月 25 日 via iPad
    似乎暴露了用了一下 publicID 233333333333
    msg7086
        8
    msg7086  
       2014 年 10 月 25 日
    @randomize 应该是可以算作回溯DFS递归。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     2769 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 25ms UTC 00:49 PVG 08:49 LAX 16:49 JFK 19:49
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86