c锟斤拷锟斤拷吧 关注:34贴子:29
  • 0回复贴,共1

求大神解题

只看楼主收藏回复

各位大神,麻烦给我解决一下这个分酒问题
有4个红酒瓶子,它们的容量分别是:9升, 7升, 4升, 2升
开始的状态是 [9,0,0,0],也就是说:第一个瓶子满着,其它的都空着.
允许把酒从一个瓶子倒入另一个瓶子,但只能把一个瓶子倒满或把一个瓶子倒空,不能有中间状态.这样的一次倒酒动作称为1次操作.
假设瓶子的容量和初始状态不变,对于给定的目标状态,至少需要多少次操作才能实现?
本题就是要求你编程实现最小操作次数的计算.
输入:最终状态(逗号分隔)
输出:最小操作次数(如无法实现,则输出-1)
例如:
输入:
9,0,0,0
应该输出:
0
输入:
6,0,0,3
应该输出:
-1
输入:
7,2,0,0
应该输出:
2
求大神给出程序


IP属地:湖北来自手机贴吧1楼2016-11-24 15:25回复