我有一个排序后的数组,如下所示:
var arr = ["a", "a", "b", "b", "b", "b", "c", "c", "c"];
有 2 个"a"
字符串、4 个"b"
字符串和 3 个"c"
字符串。
我试图返回 3 个单独的数组,从循环中一次返回一个,只包含匹配的值。因此,在第一次迭代时,返回的数组将显示为newArr = ["a", "a"]
,第二次为newArr = ["b", "b", "b", "b"]
,第三次迭代时为newArr = ["c", "c", "c"]
。
但是,这是一个预定义值的小数组,我需要一种算法,它可以对未知大小、未知元素以及未知数量的类似元素
的数组执行相同的操作。(请记住,在这种情况下,数组已经开始排序)
这是我的疯狂代码,它显示了一些不寻常且不正确的结果:
var arr = ["a", "a", "b", "b", "b", "b", "c", "c", "c"];
for(var index = 0; index < arr.length; index++)
{
var test = "";
var newArr = []; // resets the new array upon each iteration
var str = arr[index]; // initialized as the next unique index-value
for(var i = index; i < arr.length; i++)
{
if(arr[i] == str)
{
newArr.push(arr[k]);
test += arr[i] + " ";
}
else
{
index = i; // changing the outer loop variable
break; // exiting the inner loop
}
} // end of inner loop
window.alert(test);
setValues(newArr);
} // end of outer loop
function setValues(arrSorted)
{
var here = document.getElementById("here");
for(var i = 0; i < arrSorted.length; i++)
{
here.innerHTML += arrSorted[i] + " ";
}
here.innerHTML += "<br />";
} // end of setValues function