农夫、羊、菜和狼的故事(C++)

农夫、羊、菜和狼的故事
题目描述
有一个农夫带一只羊、一筐菜和一只狼过河。
如果没有农夫看管,则狼要吃羊,羊要吃菜。
但是船很小,只够农夫带一样东西过河。
问农夫该如何解此难题?
输入
题目没有任何输入。
输出
题目可能有种解决方法,求出步骤最少的解决方法,
按顺序输出农夫想把羊、菜、狼全部运过河需要哪几个步骤。
如果需要将羊带过河去则输出“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;
}
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值