用回溯解决的素数环问题,有一段代码没看懂 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
spencerqiu

用回溯解决的素数环问题,有一段代码没看懂

  •  
  •   spencerqiu 2014 年 9 月 21 日 via iPad 2509 次点击
    这是一个创建于 4234 天前的主题,其中的信息可能已经有所发展或是发生改变。
    问题:1 - 20 这 20 个数字,输出所有使相邻两个数的和皆为素数(包括第 1 个数和第 20 个数)的排列。

    下面是代码,主要是第二面的 if 语句中这段没看懂。
    search(t+1);
    b[i]=true;

    搞不懂的在于
    1.既然是回溯,比如我在搜第 5 个数的时候发现此时可使用的所有数都无法使用,似乎这里也并没有一段退回第 4 个数的第 i 次选择的代码啊……
    2.既然已经 search(t+1) 了,似乎这里就是已经退出 search(t) 了(?)那么 b[i]=true 还会被执行么?

    5 条回复    2014-09-21 07:04:59 +08:00
    GtDzx
        1
    GtDzx  
       2014 年 9 月 21 日
    感觉你对函数调用还是不很理解
    search(t+1)执行结束后会返回search(t)的b[i]:=true;继续执行
    casparchen
        2
    casparchen  
       2014 年 9 月 21 日 via iPad
    保存现场什么的
    xjx0524
        3
    xjx0524  
       2014 年 9 月 21 日
    先理解一下递归的含义吧,话说现在竞赛不是没有保送了么
    randomize
        4
    randomize  
       2014 年 9 月 21 日 via iPad
    @GtDzx
    谢谢大大,大大是说如果 search(t+1) 执行全部失败,会退回到 search(t) ,并且 b[i]=true ,然后在上一次调用继续执行?
    randomize
        5
    randomize  
       2014 年 9 月 21 日 via iPad
    @spencerqiu
    PO 主也是学 OI 的?可以留个联系方式交流一下?本人高一 C++ 。
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     928 人在线   最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 32ms UTC 22:33 PVG 06:33 LAX 15:33 JFK 18:33
    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