前言
这个问题的抛出,是几个星期之前的算法课程。老师分析了半天,最后的结论是:其实就是图的遍历。那时候挺懵逼的,不管是对于图,还是遍历,或者是数据结构,心里面都没有一个十足的概念,所以搁置了这么久的问题,现在就来好好研究清楚。
问题描述:
一个农夫在河边要过河,但是他带着一匹狼、一只羊和一颗白菜。他需要用船将这三样东西运至对岸,然而,这艘船的空间有限,只容得下他自己和另一样东西(或狼或羊或白菜)。若他不在场看管的话,狼就会吃羊,羊就会去吃白菜。此人如何才能过河。
问题分析:
抛开算法,把这个题当成是一个简单的逻辑题的话还是挺好解的,你过不了多久你就会发现几个关键的问题:
1.你要时刻注意农夫的位置,因为农夫不在地时候狼会吃羊,羊会吃菜
2.第一步只能把羊带走
3.最后一步只能是把羊从河对岸带过来
你会发现羊其实是问题的关键,只要保证羊和狼和白菜隔离开来,那么就很容易解这个问题。下面是这道题的答案:
①把羊带到河对岸 -> 把狼带到河对岸,再把羊带回来 -> 把白菜带到河对岸 -> 把羊带到河对岸
②把羊带到河对岸 -> 把白菜带到河对岸,再把羊带回来 -> 把狼带到河对岸 -> 把羊带到河对岸
算法分析:
过河问题,其实质就是一种状态的改变,就像这个问题说的,农夫狼羊菜都要从河的这边到对岸去,也就对应了两个状态,一个是没过河的状态,一个是过了河的状态。