Данные моего массива как-то повреждены моей собственной (Set Theory) функцией Complements ()? - PullRequest
0 голосов
/ 13 декабря 2010

Я был сыт по горло ограниченными функциями массива javascript и хотел написать несколько своих собственных удобных функций-прототипов для выполнения функций теории множеств.

Ниже приведен код, который у меня есть для этого до сих пор

<script type="text/javascript">

Array.prototype.contains = function(obj) {
    var i = this.length;
    while (i--) {
        if (this[i] === obj) {
            return true;
        }
    }
    return false;
}

Array.prototype.getIndices = function(obj){
    var indices = new Array();
    var i = this.length;
    while (i--) {
        if(this[i] === obj){
            indices.push(i);
        }
    }
    return indices;
}

Array.prototype.Union = function(arr){
    //combines two arrays together to return a single array containing all elements (once)
    //{1,2,3,4,5}.Union({3,4,5,6,7})
    //returns: {1,2,3,4,5,6,7}
        var primArray = this;
        var secondArray = arr;
    var i = primArray.length;
    while(i--){
        if(secondArray.contains(primArray[i])){
            primArray.splice(i, 1);
        }
    }
    var returnArr = primArray.concat(secondArray);
    return returnArr;
}

Array.prototype.Intersection = function(arr){
    //Returns an array of elements that are present in both sets
    //{1,2,3,4,5}.Intersection({3,4,5,6,7})
    //returns: {3,4,5}
        var primArray = this;
        var secondArray = arr;
    var returnArr = new Array;
    var i = 0;
    while(i++<primArray.length){
        if(secondArray.contains(primArray[i])){
            returnArr.push(primArray[i]);
        }
    }
    return returnArr;
}

Array.prototype.Complement = function(arr){
    //Returns an array of elements that are only in the primary (calling) element
    //{1,2,3,4,5}.Complement({3,4,5,6,7})
    //return: {1,2}
        var primArray = this;
        var secondArray = arr;
    var i = primArray.length;
    while(i--){
        if(secondArray.contains(primArray[i])){
            primArray.splice(i, 1);
        }
    }
    return primArray;
}

Array.prototype.SymmetricDifference = function(arr){
    //Returns elements that are exclusive to each set
    //{1,2,3,4,5}.SymmetricDifference({3,4,5,6,7})
    //return: {1,2,6,7}
        var primArray = this;
        var secondArray = arr;
    var i = primArray.length;
    while(i--){
        if(secondArray.contains(primArray[i])){
            var indices = secondArray.getIndices(primArray[i]);
            primArray.splice(i, 1);
            var j=indices.length;
            while(j--){
                secondArray.splice(indices[j], 1);
            }
        }
    }
    var returnArr = primArray.concat(arr);
    return returnArr;
}

function run(){
     var Q = "A";
     var D = [1,2,3,4,5,6,7,8,9,10];
     var sets = {
          "A":[1,2,3],
          "B":[3,4,5],
          "C":[5,6,7]
     }
     var R = D;
     for(var el in sets){
          R = R.Complement(sets[el]);
     }
//if I alert D at this point I get 8,9,10 instead of 1,2,3,4,5,6,7,8,9,10 as I would expect? What am I missing here... It causes a problem when I perform D.Complement(R) later on
     document.write(R + "<br/>");
     R = R.Union(sets[Q]);
     document.write(R + "<br/>");
  //Here!  
     R = D.Complement(R);
     document.write(R);
}

</script>

</head>

<body onload="run()">

</body>
</html>

Все работает до последней точки, когда я затем пытаюсь получить дополнение домена и мой недавно созданный набор. Ожидается, что я получу дополнение к [1,2,3,4,5,6,7,8,9,10] и [8,9,10,1,2,3], которое даст [4, 5,6,7], но когда я выполняю D.Complement (R), моя переменная D, похоже, превратилась в [1,2,3]. Похоже, это происходит после перечисления, которое я выполняю.

Я подумал, что это может быть из-за того, что я использовал this.splice и arr.splice в своих функциях, и когда я передавал переменные в функции, они передавались как указатели, означающие, что я фактически работал над реальными ячейками памяти. Поэтому я использовал primArray и secondArray, чтобы создать дубликат для работы ... но проблема все еще возникает

Большое спасибо

1 Ответ

1 голос
/ 13 декабря 2010

Поэтому я использовал primArray и secondArray, чтобы создать дубликат для работы ... но проблема все еще возникает

Простое присвоение переменной не делает его новым массивом, вы все еще работаете с переданным массивом. Вы должны вручную создать новую копию массива, либо циклически пройдя ее, и скопировать каждый индекс или путем объединения и расщепления.

...