題目:
5 個(gè)沉默寡言的哲學(xué)家圍坐在圓桌前,每人面前一盤(pán)意面。叉子放在哲學(xué)家之間的桌面上火本。(5 個(gè)哲學(xué)家,5 根叉子)
所有的哲學(xué)家都只會(huì)在思考和進(jìn)餐兩種行為間交替聪建。哲學(xué)家只有同時(shí)拿到左邊和右邊的叉子才能吃到面钙畔,而同一根叉子在同一時(shí)間只能被一個(gè)哲學(xué)家使用。每個(gè)哲學(xué)家吃完面后都需要把叉子放回桌面以供其他哲學(xué)家吃面金麸。只要條件允許擎析,哲學(xué)家可以拿起左邊或者右邊的叉子,但在沒(méi)有同時(shí)拿到左右叉子時(shí)不能進(jìn)食。
假設(shè)面的數(shù)量沒(méi)有限制揍魂,哲學(xué)家也能隨便吃桨醋,不需要考慮吃不吃得下。
設(shè)計(jì)一個(gè)進(jìn)餐規(guī)則(并行算法)使得每個(gè)哲學(xué)家都不會(huì)挨餓现斋;也就是說(shuō)喜最,在沒(méi)有人知道別人什么時(shí)候想吃東西或思考的情況下,每個(gè)哲學(xué)家都可以在吃飯和思考之間一直交替下去庄蹋。
哲學(xué)家從 0 到 4 按 順時(shí)針 編號(hào)瞬内。請(qǐng)實(shí)現(xiàn)函數(shù) void wantsToEat(philosopher, pickLeftFork, pickRightFork, eat, putLeftFork, putRightFork):
philosopher 哲學(xué)家的編號(hào)。
pickLeftFork 和 pickRightFork 表示拿起左邊或右邊的叉子限书。
eat 表示吃面虫蝶。
putLeftFork 和 putRightFork 表示放下左邊或右邊的叉子。
由于哲學(xué)家不是在吃面就是在想著啥時(shí)候吃面倦西,所以思考這個(gè)方法沒(méi)有對(duì)應(yīng)的回調(diào)能真。
給你 5 個(gè)線程,每個(gè)都代表一個(gè)哲學(xué)家调限,請(qǐng)你使用類的同一個(gè)對(duì)象來(lái)模擬這個(gè)過(guò)程舟陆。在最后一次調(diào)用結(jié)束之前,可能會(huì)為同一個(gè)哲學(xué)家多次調(diào)用該函數(shù)耻矮。
示例:
輸入:n = 1
輸出:[[4,2,1],[4,1,1],[0,1,1],[2,2,1],[2,1,1],[2,0,3],[2,1,2],[2,2,2],[4,0,3],[4,1,2],[0,2,1],[4,2,2],[3,2,1],[3,1,1],[0,0,3],[0,1,2],[0,2,2],[1,2,1],[1,1,1],[3,0,3],[3,1,2],[3,2,2],[1,0,3],[1,1,2],[1,2,2]]
解釋:
n 表示每個(gè)哲學(xué)家需要進(jìn)餐的次數(shù)秦躯。
輸出數(shù)組描述了叉子的控制和進(jìn)餐的調(diào)用,它的格式如下:
output[i] = [a, b, c] (3個(gè)整數(shù))
- a 哲學(xué)家編號(hào)裆装。
- b 指定叉子:{1 : 左邊, 2 : 右邊}.
- c 指定行為:{1 : 拿起, 2 : 放下, 3 : 吃面}踱承。
如 [4,2,1] 表示 4 號(hào)哲學(xué)家拿起了右邊的叉子。
提示:
1 <= n <= 60
java代碼: