回溯——四人分酒问题

http://blog.chinaunix.net/u/30202/showart_391485.html

http://bjydfq.itpub.net/post/7617/42768

题目:两瓶 8 两的酒,一个 3 两的杯子,瓶和杯子都没有刻度,如何将酒平均分给四个人喝?也就是每个人分 4 两酒,也没什么限制条件,当然,喝过的酒不能再吐出来(: > )。

思路:回溯算法,递归

对当前酒瓶,杯和人当前存的酒量设定为一种状态,最初始的状态为( 880 0000 ),最终的状态为( 000 4444 ),状态的改变为分酒的选择,一共有 18 种选择:

A 类:瓶子到杯子, 2

B 类:杯子到瓶子, 2

C 类:杯子到人, 4

D 类:瓶子到人, 8

E 类:瓶子到瓶子, 2 种(我没有考虑)。

F 类:人到杯子,人到瓶子,人到人不被允许。

不能用简单穷举,因为,如果穷举,要达到可行解,需要 18^24 次方这么多尝试,计算机没能力计算这么多步的。

回溯方法是深度搜索,选定一个方法一路向下走,直到没得路可走了,也就是所有的选择都到达了非法的状态,那么回到上一个状态,选择下一个选择,这样一路到达可行解。虽然不是最优的,一定是最快的。

实现代码如下:


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值