刷题一点感悟

一、不够细心

  • 运用深度优先搜索的时候,复原现场做得不好:用来控制下一步方向的变量 tmp_x, tmp_y 经常没有复原;

二、对算法理解不足,应用不够灵活

  • 遇到搜索的问题时,习惯使用 dfs ,但 dfs 并不是万能的、在很多问题里面也并不是最优解。例如下题。因 dfs 与顺序有关、但下题则不需要顺序(即如图二所示、按照 “ 2 -> 6 -> 7 -> 11 -> 12 ” 的顺序剪邮票与按照 “ 12 -> 11 -> 7 -> 6 -> 2 ” 的顺序是一样的),所以单纯使用 dfs 会导致最终结果有很多重复。这是做题初始没有意识到的。

【剪邮票】

如图1所示,有12张连在一起的12生肖的邮票。现在你要从中剪5张来,要求必须是连着的。注意仅仅连接一个角不算相连。
如图2、3,粉红色所示部分就是合格的剪取。

请你计算,一共有多少种不同的剪取方法。

图一
图二
图三

 

  • 同以上题为例,运用 dfs 算法可以从 “搜索 -> 枚举” 到 “枚举 -> 搜索”。
  • 灵活是需要做题的。

三、可以沮丧,但不要丧太久啦。

要努力嘤嘤嘤

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值