js實現(xiàn)杯子倒水問題自動求解程序
智力測試題經(jīng)常遇到類似的邏輯題,給幾個容量不等的杯子,讓你倒出多少的水。
安卓上有一款專門玩這個題的游戲叫做Water Logic.

做為程序員的我們,玩這類題目應(yīng)該都沒問題,10步以內(nèi)的都可以輕松搞定,10步以上的也可以搞定但未必能夠輕松達到最少步數(shù)。
有3顆星強迫癥的玩家兼程序員,寫出這么個自動求解的小程序,以后這個問題再也不是問題了。

算法基本邏輯:
每個杯子有倒?jié)M、倒空、倒入其它杯子的操作,所以總共是: 杯子數(shù)*(杯子數(shù)-1+2)
對于3只杯子的情況,每一步可選的操作有12種. 如果2個杯子則每步可選操作有6種。
遍歷每一種操作,記錄操作完成后各個杯子內(nèi)的水量,以水量計算出一個key來建立map.
遍歷各種倒水操作的過程中,如果key已經(jīng)存在且當(dāng)前步數(shù)大于先前記錄的步數(shù)則舍棄該操作。
這個小程序只能解決2個杯子或3個杯子的倒水問題,并沒有寫成N個杯子通用的,代碼有很多hard code。
相關(guān)文章
Javascript oop設(shè)計模式 面向?qū)ο缶幊毯唵螌嵗榻B
這篇文章主要介紹了Javascript oop設(shè)計模式 面向?qū)ο缶幊毯唵螌嵗榻B的相關(guān)資料,這里附有實例代碼幫助大家學(xué)習(xí)理解,需要的朋友可以參考下2016-12-12
獲取當(dāng)前點擊按鈕的id用this.id實現(xiàn)
這篇文章主要介紹了獲取當(dāng)前點擊按鈕的id的方法,,需要的朋友可以參考下2014-03-03
javascript之querySelector和querySelectorAll使用介紹
其實關(guān)于querySelector和querySelectorAll的介紹說明很多。在此主要是做個記錄2011-12-12

