我有一個程序詢問用戶的問題。如果用戶不知道答案,他可以跳過它。洗牌回收數據的算法
但是,如果他的答案錯了,那麼這個問題會被分配負面的分數,然後在測驗中的任何時候都必須隨機提問。
如果問題得到正確回答,則不需要再次詢問問題。
有沒有任何算法來洗牌這樣的問題?
我有一個程序詢問用戶的問題。如果用戶不知道答案,他可以跳過它。洗牌回收數據的算法
但是,如果他的答案錯了,那麼這個問題會被分配負面的分數,然後在測驗中的任何時候都必須隨機提問。
如果問題得到正確回答,則不需要再次詢問問題。
有沒有任何算法來洗牌這樣的問題?
解決此問題的一種方法是將問題存儲在priority queue中。最初n
問題被分配優先級1到n
。隨後,當您想要回收問題時,請爲其分配從x
到n + 1
隨機選擇的新優先級,其中x
是已從優先級隊列中移除的問題數。現在您重新插入問題並照常進行。
如果您使用堆實現優先級隊列,則在處理相同優先級的元素時會面臨兩難的局面。一般情況下,只要元素鍵相等,您就會停止在堆中冒泡。在你的情況下,這會對測驗產生不利影響,因爲同等優先級的元素將不會被隨機排序—它們在堆中的位置取決於插入的順序。
通過使用雙精度浮點值可以解決此問題。現在最初的優先級是1.0,2.0,3.0等等。隨後,您從範圍[1.0 * x, n + 1.0]
中選擇一個隨機浮點值,其中,x
是從優先級隊列中刪除的問題數,n
是您開始的問題數。現在,您不會遇到同等密鑰的問題,因爲您幾乎沒有機會選擇其中一個現有的雙精度值。這個機會實際上並不是零,但它比今天流星將撞擊你的計算機的可能性要小。
是的,有一個算法。你想讓我們爲你的作業寫答案嗎? –
是的,應該有一個算法,現在你所要做的就是找出然後嘗試。稍後當你遇到問題時,請回到這裏。 :) – Haris
這是一個很好的問題。提問者有一個他想解決的具體問題,他正在尋找一種算法來實現它。看到這個元問題:http://meta.stackoverflow.com/questions/271842/is-it-okay-to-just-ask-for-an-algorithm-to-a-problem –