gpt4 book ai didi

Clojure:连续重复项的数量

转载 作者:行者123 更新时间:2023-12-02 10:05:17 28 4
gpt4 key购买 nike

我需要一个函数来计算序列中连续相等条目的数量。例如,(连续的“abcdefg”)应返回0,而(连续的“aabcdddefg”)应返回3。

我写的方式是否惯用或者可以改进吗?

(defn consecutive [p]
(second (reduce
#(vector %2
(if (= (first %1) %2)
(inc (second %1))
(second %1)))
[nil 0]
p)))

最佳答案

我认为(连续的“abcdefg”)应该返回1,而不是0。

这是实现此目的的简单实现:

(defn consecutive [s] 
(apply max (map count (partition-by identity s))))

关于Clojure:连续重复项的数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11561295/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com