New hanoi

/*通过这个题目,个人对汉诺塔有了更深的理解。首先这个hanoi题用了一种贪心的思想,每次先移动最大的盘。因为最大的盘一旦移到最终位置,就不需要再移动了。然后,还有就是汉诺塔移动规则:汉诺塔移动,每次都要通过一根过渡柱子,才能达到ta的终极状态。(问题的关键就在这根过渡柱子),就像要想把标号1柱子上的第k个盘子移动到标号3的柱子上,那么我们必须将k-1个盘通过移动到标号3的柱子移动到标号2的柱子上。 */

/*代码实现如下*/
#include <iostream>
#define N 64
using namespace std;
int x[N],y[N],r;
string s=" ABC";
void hanoi(int k,int temp)
{
	int i,j;
	if(x[k]==temp ) return;
	for(i=1;i<4;i++)
		if(x[k]!=i && i!=temp)break;
	for(j=k-1;j>0;j--) hanoi(j,i);
	r++;
	cout<<"move "<<k<<" from "<<s[x[k]]<<" to "<<s[temp]<<endl;
	x[k]=temp;
}
int main ()
{
	//freopen("t.txt","r",stdin);
	int i,k,t,n,m,tenp;
	cin>>t;
	while(t--)
	{
		cin>>m;
		for(k=1;k<4;k++)
		for(cin>>n,i=0;i<n;i++) 
		{cin>>tenp;x[tenp]=k;}
		for(k=1;k<4;k++)
		for(cin>>n,i=0;i<n;i++) 
		{cin>>tenp;y[tenp]=k;}
		for(r=0,k=m;k>0;k--)
			hanoi(k,y[k]);
		cout<<r<<endl;
	}
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值