农夫、羊、菜和狼的故事(状态空间搜索或直接穷举方法打印出来)


Problem Link:http://www.cnblogs.com/zandbin/p/5341656.html


题目1204:农夫、羊、菜和狼的故事

时间限制:1 秒

内存限制:32 兆

特殊判题:

提交:903

解决:606

题目描述:

有一个农夫带一只羊、一筐菜和一只狼过河.
果没有农夫看管,则狼要吃羊,羊要吃菜.
但是船很小,只够农夫带一样东西过河。
问农夫该如何解此难题?

输入:

题目没有任何输入。

输出:

题目可能有种解决方法,求出步骤最少的解决方法,
按顺序输出农夫想把羊、菜、狼全部运过河需要哪几个步骤。
如果需要将羊带过河去则输出“sheep_go”。
如果需要将羊带回来则输出“sheep_come”。
如果需要将菜带过河去则输出“vegetable_go”。
如果需要将菜带回来则输出“vegetable_come”。
如果需要将狼带过河去则输出“wolf_go”。
如果需要将狼带回来则输出“wolf_come”。
如果需要空手返回则输出“nothing_come”。
如果需要空手过河则输出“nothing_go”。
每输出一种方案,输出一行“succeed”。

样例输入:
 
    
样例输出:
 
    
提示:

题目可能有多组解决方法,每种方法输出后要再空一行。
一种方法中的多句话,每句话占一行。

来源:
2008年华中科技大学计算机保研机试真题
AC code:

#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<map>
#include<math.h>
#include<string.h>
#include<queue>
#include<vector>
#include<set>
#define LL long long
#define exp 1e-9
#define MAXN 1000010

using namespace std;

int main()
{
//	freopen("D:\\in.txt","r",stdin);
    printf("sheep_go\n");
    printf("nothing_come\n");
    printf("vegetable_go\n");
    printf("sheep_come\n");
    printf("wolf_go\n");
    printf("nothing_come\n");
    printf("sheep_go\n");
    printf("succeed\n");
    printf("\n");
    
    printf("sheep_go\n");
    printf("nothing_come\n");
    printf("wolf_go\n");
    printf("sheep_come\n");
    printf("vegetable_go\n");
    printf("nothing_come\n");
    printf("sheep_go\n");
    printf("succeed\n");
    printf("\n");
    
    return 0;
}


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个简单的C++实现,用于解决农夫过河问题: ```c++ #include <iostream> #include <cstring> using namespace std; bool is_valid_state(int wolf, int goat, int cabbage) { // 判断当前状态是否合法 if ((goat == cabbage) && (wolf != goat)) return false; if ((wolf == goat) && (goat != cabbage)) return false; return true; } void dfs(int wolf, int goat, int cabbage, int farmer, int depth, char path[]) { if (depth == 8) { path[depth] = '\0'; cout << path << endl; // 打印路径 return; } // 农夫从左岸到右岸 if (farmer == 0) { if (is_valid_state(wolf, goat, cabbage + 1)) { path[depth] = 'C'; dfs(wolf, goat, cabbage + 1, 1, depth + 1, path); } if (is_valid_state(wolf, goat + 1, cabbage)) { path[depth] = 'G'; dfs(wolf, goat + 1, cabbage, 1, depth + 1, path); } if (is_valid_state(wolf + 1, goat, cabbage)) { path[depth] = 'W'; dfs(wolf + 1, goat, cabbage, 1, depth + 1, path); } } // 农夫从右岸到左岸 else { if (is_valid_state(wolf, goat, cabbage - 1)) { path[depth] = 'c'; dfs(wolf, goat, cabbage - 1, 0, depth + 1, path); } if (is_valid_state(wolf, goat - 1, cabbage)) { path[depth] = 'g'; dfs(wolf, goat - 1, cabbage, 0, depth + 1, path); } if (is_valid_state(wolf - 1, goat, cabbage)) { path[depth] = 'w'; dfs(wolf - 1, goat, cabbage, 0, depth + 1, path); } } } int main() { int wolf = 1, goat = 1, cabbage = 1, farmer = 0; char path[9]; // 存储路径 dfs(wolf, goat, cabbage, farmer, 0, path); return 0; } ``` 在上面的实现中,我们使用深度优先搜索算法(DFS)来穷举所有可能的状态,并使用 `is_valid_state()` 函数来判断当前状态是否合法。一旦找到一条可行路径,就会打印出该路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林下的码路

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值