Массив уникальных значений - PullRequest
0 голосов
/ 22 июля 2010

Имея дело с JSON, возвращенным из YQL, я нашел способ извлечь все уникальные значения из массива.

function uniqueArrayValues(o){
      var items = o.query.results.row,
          output = [];

  function check(val){
    for(var c=0; c<output.length; c++){
      if(output[c] === val){
        return false;
        }
    }
     return true;
  }

 for(var i=1; i<items.length; i++){
   if(check(items[i].team)){
     output.push(items[i].team);
    }    
  }

  return output;
}

Код выглядит слишком «загруженным», и мне было интересно, есть ли более элегантный способ извлечения уникальных значений из массива.

Ответы [ 2 ]

1 голос
/ 22 июля 2010

Вы можете использовать indexOf, чтобы проверить, находится ли элемент в массиве.

 function check(val){
        return output.indexOf(val) != -1;
    }

или используйте объект вместо массива, если у вас есть уникальный идентификатор или имя: var output = {}

for(var i=1; i<items.length; i++){
   if(!output[items[i].team.id])){
     output [items[i].team.id] = items[i].team;
    }    
  }
0 голосов
/ 22 июля 2010

Если ваш массив имеет нетривиальную длину, стандартным способом извлечения уникальных элементов является сортировка или хэширование массива.

РЕДАКТИРОВАТЬ: некоторые псевдокод

sort array
last = unused
for each v in array do
  if v != last
     uniqueArray.push_back(v)
     last = v
  end if
end for
// uniqueArray now contains the unique elements of array
...