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

题目描述:

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

输入:

题目没有任何输入。

输出:

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

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

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

来源:

2008年华中科技大学计算机保研机试真题

#include
void create(void);
int safe(int,int j,int m,int n);
int isLink(int ,int);
void dfs(int);
void out(void);

struct problem{
	int farmer;
	int wolf;
	int sheep;
	int vegetable;
}; 

int visit[16];
int max=0;
int pa=0;
struct problem p[16];
int link[16][16];
int path[16];

int main(){
	int i;
	for(i=0;i<16;i++) visit[i]=0;
	create();
	dfs(0);
	return 0;
}

void create(){
	int i,j,m,n;
	for(i=0;i<2;i++)
		for(j=0;j<2;j++)
			for(m=0;m<2;m++)
				for(n=0;n<2;n++){
					if(safe(i,j,m,n)){
						p[max].farmer=i;
						p[max].wolf=j;
						p[max].sheep=m;
						p[max].vegetable=n;
						max++;
					}
				}
	max--;
	for(i=0;i<=max;i++)
		for(j=0;j<=max;j++){
			if(isLink(i,j))
				link[i][j]=1;
			else 
				link[i][j]=0;
		}
}

int safe(int i,int j,int m,int n){
	if(i!=m&&(j==m||m==n))	return 0;
	return 1;
}

int isLink(int i,int j){
	int k=0;
	if(p[i].wolf!=p[j].wolf) k++;
	if(p[i].sheep!=p[j].sheep) k++;
	if(p[i].vegetable!=p[j].vegetable) k++;
	if(p[i].farmer!=p[j].farmer&&k<=1) return 1;
	return 0;
}

void dfs(int n){
	int i;
	visit[n]=1;
	path[pa++]=n;
	if(n==max){
		out();
		return;
	}
	for(i=0;i<=max;i++){
		if(link[n][i]&&!visit[i]){
			dfs(i);
			pa--;
			visit[i]=0;	
		}
	}
}

void out(){
	int i;
	for(i=1;i


你可能感兴趣的:(题目1204:农夫、羊、菜和狼的故事)