配列の並び替え

13674 ワード

配列
方法ES 6セット方法で重さを取ります.
function unique (arr) {
    return Array.from(new Set(arr))
}
方法二indexOf
function unique (arr) {
    var result = []; //    
    for(var i = 0; i < arr.length; i++) {
        //       result     arr[i],  arr[i]      result 
        if (result.indexOf(arr[i]) == -1) result.push(arr[i]);
    }
    return result;
}
方法3 filterを使う
function unique(arr) {
  	return arr.filter(function(item, index, arr) {
    	//    ,            ==     ,        
    	return arr.indexOf(item, 0) === index;
  	});
}
方法4は同様にSet方法であるが、コードは簡略化される.
[...new Set(arr)]
配列の並べ替え
方法一泡並べ替え
var arr = [3, 1, 4, 6, 5, 7, 2];

function bubbleSort(arr) {
	for (var i = 0; i < arr.length - 1; i++) {
	    for(var j = 0; j < arr.length - i - 1; j++) {
	        if(arr[j + 1] < arr[j]) {
	            var temp;
	            temp = arr[j];
	            arr[j] = arr[j + 1];
	            arr[j + 1] = temp;
	        }
	    }
	}
	return arr;
}

console.log(bubbleSort(arr));
方法二快速並べ替え–二分割法を採用して、中間数を取り出します.配列は毎回と中間数を比較して、小さいのは左に置いて、大きいのは右に置きます.
var arr = [3, 1, 4, 6, 5, 7, 2];

function quickSort(arr) {
    if(arr.length == 0) {
        return [];    //      
    }

    var cIndex = Math.floor(arr.length / 2);
    var c = arr.splice(cIndex, 1);
    var l = [];
    var r = [];

    for (var i = 0; i < arr.length; i++) {
        if(arr[i] < c) {
            l.push(arr[i]);
        } else {
            r.push(arr[i]);
        }
    }

    return quickSort(l).concat(c, quickSort(r));
}

console.log(quickSort(arr));