农夫、羊、菜和狼的故事
题目描述
有一个农夫带一只羊、一筐菜和一只狼过河。
如果没有农夫看管,则狼要吃羊,羊要吃菜。
但是船很小,只够农夫带一样东西过河。
问农夫该如何解此难题?
输入
题目没有任何输入。
输出
题目可能有种解决方法,求出步骤最少的解决方法,
按顺序输出农夫想把羊、菜、狼全部运过河需要哪几个步骤。
如果需要将羊带过河去则输出“sheep_go”。
如果需要将羊带回来则输出“sheep_come”。
如果需要将菜带过河去则输出“vegetable_go”。
如果需要将菜带回来则输出“vegetable_come”。
如果需要将狼带过河去则输出“wolf_go”。
如果需要将狼带回来则输出“wolf_come”。
如果需要空手返回则输出“nothing_come”。
如果需要空手过河则输出“nothing_go”。
每输出一种方案,输出一行“succeed”。
样例输入 复制
无输入。
样例输出 复制
输出符合要求的答案。
解析:
本体要求输出步数最小的答案,但是步数最小的答案有两个,所以两个都要输出,不然提交就会WA。
#include<iostream>
using namespace std;
int main()
{
cout<<"sheep_go"<<endl;
cout<<"nothing_come"<<endl;
cout<<"wolf_go"<<endl;
cout<<"sheep_come"<<endl;
cout<<"vegetable_go"<<endl;
cout<<"nothing_come"<<endl;
cout<<"sheep_go"<<endl;
cout<<"succeed"<<endl;//第一种方案已经输出完毕,输出一个"succeed".
cout<<"sheep_go"<<endl;
cout<<"nothing_come"<<endl;
cout<<"vegetable_go"<<endl;
cout<<"sheep_come"<<endl;
cout<<"wolf_go"<<endl;
cout<<"nothing_come"<<endl;
cout<<"sheep_go"<<endl;
cout<<"succeed";
return 0;
}