河内问题塔

时间:2011-04-26 20:24:10

标签: c++

嗨大家我在河内塔遇到了问题:
我们给了一堆替代颜色的圆柱体交替堆叠在一起。
工作是将两个相同颜色的堆叠分开 我可以使用递归为常规的河内塔编写代码(算法),但我无法弄清楚这一部分。有人可以帮忙吗? 常规河内问题的代码:

#include<iostream>

using namespace std;
int count=0;

void hanoi(char a,char b,char c,int x)
{
  if(x>1)
  {
    hanoi(a,c,b,x-1);
    hanoi(a,b,c,1);
    hanoi(c,b,a,x-1);
  }
  else
  {
    cout<<"Move a Disk from "<<a<<" to "<<b<<endl; count++;  
  }
}

int main()
{
  int n;
  cout<<"Enter the height of stack";
  cin>>n;
  hanoi('A','B','C',n);
  cout<<"\nNo. of changes done:"<<count;

  return 0;
}

2 个答案:

答案 0 :(得分:5)

解决问题n次,交替使用解决方案。

int main()
{
    int n;
    cout<<"Enter the height of stack";
    cin>>n;

    char startPeg = 'A';
    char interPeg = 'B';
    char slnPeg = 'C';

    while(n > 0) {
        hanoi(startPeg,interPeg,slnPeg,n);
        n--;
        char temp = startPeg;
        startPeg = slnPeg;
        slnPeg = temp;
    }

    return 0;
}

这是它的工作原理。假设我们的堆栈颜色为红色(R)和黄色(Y),高度为5个单位:

     |           |           |
    Y|Y          |           |
   RR|RR         |           |
  YYY|YYY        |           |
 RRRR|RRRR       |           |
YYYYY|YYYYY      |           |     

第一次运行后,它看起来像这样:

     |           |           |
     |           |          Y|Y    
     |           |         RR|RR
     |           |        YYY|YYY
     |           |       RRRR|RRRR
     |           |      YYYYY|YYYYY

第二次运行后,它看起来像这样:

     |           |           |    
    Y|Y          |           |
   RR|RR         |           |
  YYY|YYY        |           |
 RRRR|RRRR       |      YYYYY|YYYYY

第三次运行后,它看起来像这样:

     |           |           |    
     |           |          Y|Y
     |           |         RR|RR
     |           |        YYY|YYY
 RRRR|RRRR       |      YYYYY|YYYYY

第四轮之后,这个:

     |           |           |    
     |           |           |
    Y|Y          |           |
   RR|RR         |        YYY|YYY
 RRRR|RRRR       |      YYYYY|YYYYY

在第五次也是最后一次运行之后,这个:

     |           |           |    
     |           |           |
     |           |          Y|Y
   RR|RR         |        YYY|YYY
 RRRR|RRRR       |      YYYYY|YYYYY

此时你已经完成了。

如果您非常渴望递归,请执行以下操作:

void painful(char start, char inter, char sln, int n) {
    if(n == 0) return;
    hanoi(start,inter,sln);
    painful(sln,inter,start,n-1);
}

int main()
{
    int n;
    cout<<"Enter the height of stack";
    cin>>n;

    painful('A','B','C',n);

    return 0;
}

答案 1 :(得分:0)

#include <stdio.h>
hanoi(char a, char b, char c, int h) {
    if(h<=1){
        printf("move:%c to %c :\n", a, b );
    }else{
        hanoi(a,c,b, h-1);
        hanoi(a,b,c, 1);
        hanoi(c,b,a, h-1);
    }
}
main(){
    int input;
    int i ;
    scanf("%d", &input);
    /* A is the src and B is dest */
    for(i=1; i< input ; i++){
        if(i%2){
            hanoi('A', 'B', 'C', input-i);
        }else{
            hanoi('B', 'A', 'C', input-i);
        }
    }
}
// work ?