配列の並び替え
13674 ワード
配列
方法ES 6セット方法で重さを取ります.
方法一泡並べ替え
方法ES 6セット方法で重さを取ります.
function unique (arr) {
return Array.from(new Set(arr))
}
方法二indexOffunction 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));