汉诺塔解法(C/C++)

#include<iostream>
#include<string>

using namespace std;

void Hanoi(int n, string start, string middle, string end);

void move(int n, string start, string end)
{
    cout << "move:" << start << "->" << end << endl;
}

void exchange(int n, string start, string middle, string end)
{
    Hanoi(n - 1, start, end, middle);
    move(n, start, end);
    Hanoi(n - 1, middle, start, end);
}

void Hanoi(int n, string start, string middle, string end)
{
    return (n == 1) ? move(n, start, end) : exchange(n, start, middle, end);
}


int main(int argc, char** argv)
{
    int n;
    string start = "@", middle = "#", end = "$";

    n = argc > 1 ? atoi(argv[1]) : 3;
    cout << "The solution for n =" << n << endl;
    Hanoi(n, start, middle, end);

    return 0;
}

posted on 2004-07-17 15:34  Anthony-黄亮  阅读(124)  评论(0编辑  收藏  举报

导航