0

我有一个字符串数组或大小为 M(M>n) 的数字。我想检查是否有任何 n 个连续元素相同,其中 n 可以在 1-M 之间变化。

例如,假设我在数组下方,并且我想检查是否存在四个连续的“5”或两个连续的“3”:

{1,2,3,4,5,5,5,5,2,6,3,3,1}

我怎样才能做到这一点?

PS 我还使用 Linq.JS 在数组上执行 linq 函数。

4

1 回答 1

2

你可以这样做

var arr = [1,2,3,4,5,5,5,5,2,6,3,3,1],
 result = arr.reduce((p,c,i,a) => c !== a[i+1] ? (p[p.length-1][0] = c, p.concat([[0,1]]))
                                               : (p[p.length-1][0] = c, p[p.length-1][1]++, p),[[true,1]])
             .slice(0,-1);
console.log(result);

于 2016-09-18T20:45:44.463 回答