小編給大家分享一下C++如何實現(xiàn)漢諾塔,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
網(wǎng)站建設哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁設計、網(wǎng)站建設、微信開發(fā)、小程序開發(fā)、集團企業(yè)網(wǎng)站建設等服務項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了平度免費建站歡迎大家使用!
C++ 實現(xiàn)漢諾塔的實例詳解
前言:
有A,B,C三塔,N個盤(從小到大編號為1-N)起初都在A塔,現(xiàn)要將N個盤全部移動到C塔(按照河內塔規(guī)則),求最少移動次數(shù)以及每次的移動詳細情況。
要求:
需要采用遞歸方法和消除尾遞歸兩種方法編寫。
盤數(shù)N由用戶從標準輸入讀入,以一個整數(shù)表示,然后請調用兩個方法按照下面例子所述分別在屏幕中輸出結果(正常情況下一個輸入數(shù)據(jù)會顯示同樣的輸出結果2次)。
實現(xiàn)代碼:
#includeusing namespace std; void move(int count,char start='a',char finish='b',char temp='c') { if(count>0) { move(count-1,start,temp,finish); cout<<"Move "< 0) { move_without_recursion(count-1,start,temp,finish); cout<<"Move "< >count; cout<<"遞歸方法運行過程:"< 以上是“C++如何實現(xiàn)漢諾塔”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
新聞名稱:C++如何實現(xiàn)漢諾塔
文章地址:http://weahome.cn/article/gdjogc.html