在Javascript中从2d数组中删除重复项

时间:2009-02-06 11:04:51

标签: javascript algorithm sorting

如下所示删除数组上的欺骗是一个很好的算法...

    var allwords = [

    ['3-hidroxitiramina', '3-hidroxitiramina'],

    ['3-hidroxitiramina', '3-hidroxitiramina'],

    ['3-in-1 block', 'bloqueo 3 en 1'],

    ['abacterial', 'abacteriano'],

    ['abacteriano', 'abacteriano'],

    ['abciximab', 'abciximab'],

...

为了澄清,我想要其中一个

['3-hidroxitiramina', '3-hidroxitiramina'],

要删除,所以只有一个

3 个答案:

答案 0 :(得分:0)

您可以将对象用作关联数组/哈希(如果您的意思是第一维中的重复)

var allWordsObj = {};
for( var i = 0; i < allWords.length; i++ ) {
    allWordsObj[allWords[i][0]] = allWords[i][1];
}

alert( allWordsObj['3-hidroxitiramina'] );

答案 1 :(得分:0)

试试这个:

var len = allwords.length, i, j, first;
for (i=0; i<len-1; i++) {
    first = allwords[i].toString();
    for (j=i+1; j<len; j++) {
        if (first === allwords[j].toString()) {
            allwords.splice(j, 1);
            len--;
        }
    }
}

答案 2 :(得分:0)

[编辑]:误读,在阅读澄清后我建议:

 var i = allwords.length-1, prev='';
 do {
     if (allwords[i].join('/') === prev) {
        allwords.splice(i,1);
     }
     prev = allwords[i].join('/');
 } while (i-- && i>-1);

(扭转循环是一个优化步骤)