只是爲了completenes,純Clojure的版本可能是這樣的:
(defn deque
([]
'[()()])
([& elems]
[elems '()]))
(defn push-front [deque elem]
(let [[head tail] deque]
[(cons elem head) tail]))
(defn push-back [deque elem]
(let [[head tail] deque]
[head (cons elem tail)]))
(defn pop-front [deque]
(let [[head tail] deque]
(if (empty? head)
[(-> tail reverse rest) head]
[(rest head) tail])))
(defn pop-back [deque]
(let [[head tail] deque]
(if (empty? tail)
[tail (-> head reverse rest)]
[head (rest tail)])))
(defn peek-front [deque]
(let [[head tail] deque]
(if (empty? head)
(-> tail reverse first)
(first head))))
(defn peek-back [deque]
(let [[head tail] deque]
(if (empty? tail)
(-> head reverse first)
(first tail))))
;; usage example:
user> (let [dq (deque)]
(-> dq
(push-front :a)
(push-front :b)
(peek-back)))
:a
user> (let [dq (deque)]
(-> dq
(push-front :a)
(push-front :b)
(pop-back)))
[() (:b)]
user> (let [dq (deque)]
(-> dq
(push-back :a)
(push-back :b)
(peek-back)))
:b
非常感謝。其實在我的問題中,我的意思是** java.util.DeQueue **而不是** java.util.Queue **。但是,無論您的答案如何(我會糾正我的問題)。特別感謝java.util.ArrayDeque(它爲Deque提供了一個實現)的建議。我曾見過[deque-clojure](https://github.com/pjstadig/deque-clojure/blob/master/test/name/stadig/test/deque.clj),但希望有更簡單的東西(我不能按照代碼)。 – DarrylG