如何根据每个元素的长度对数组进行排序?

问题描述 投票:0回答:12

我有一个像这样的数组:

arr = []
arr[0] = "ab"
arr[1] = "abcdefgh"
arr[2] = "abcd"

排序后,输出数组应为:

arr[0] = "abcdefgh"
arr[1] = "abcd"
arr[2] = "ab"  

我想要每个元素长度的

descending
顺序。

javascript arrays string sorting
12个回答
310
投票

您可以使用

Array.sort
方法对数组进行排序。回调函数应该使用item的长度作为排序标准:

// sort ascending - shorter items first
arr.sort((a, b) => a.length - b.length);

// sort descending - longer items first
arr.sort((a, b) => b.length - a.length);

如果两个项目的长度相同,您可以指定附加条件:

// sort by length
// if equal then sort by dictionary order
["c", "a", "b"].sort((a, b) => a.length - b.length || a.localeCompare(b));

13
投票

我们可以使用 Array.sort 方法来对这个数组进行排序。

ES5解决方案

var array = ["ab", "abcdefgh", "abcd"];

array.sort(function(a, b){return b.length - a.length});

console.log(JSON.stringify(array, null, '\t'));

对于升序排序顺序:

a.length - b.length

对于降序排序顺序:

b.length - a.length

ES6解决方案

注意:并非所有浏览器都能理解ES6代码!

在 ES6 中我们可以使用 箭头函数表达式

let array = ["ab", "abcdefgh", "abcd"];

array.sort((a, b) => b.length - a.length);

console.log(JSON.stringify(array, null, '\t'));


5
投票

使用现代 JavaScript,你可以这样做:

降序排列

const arr = [
  "ab",
  "abcdefgh",
  "abcd",
  "abcdefghijklm"
];

arr.sort((a, b) => b.length - a.length);

console.log(JSON.stringify(arr, null, 2));

升序 - 只需将

a
b

切换即可

const arr = [
  "ab",
  "abcdefgh",
  "abcd",
  "abcdefghijklm"
];

arr.sort((a, b) => a.length - b.length);

console.log(JSON.stringify(arr, null, 2));


3
投票

这是排序,取决于使用 javascript 的字符串的长度,按照您的要求使用冒泡排序

var arr = ['1234', '12', '12345', '1'];

bubbleSort(arr );

function bubbleSort(a) {
    var swapped;
    do {
        swapped = false;
        for (var i = 0; i < a.length - 1; i++) {
            if (a[i].length < a[i + 1].length) {
                var temp = a[i];
                a[i] = a[i + 1];
                a[i + 1] = temp;
                swapped = true;
            }
        }
    } while (swapped);
}

console.log(arr );


1
投票
#created a sorting function to sort by length of elements of list
def sort_len(a):
    num = len(a)
    d = {}
    i = 0
    while i<num:
        d[i] = len(a[i])
        i += 1
    b = list(d.values())
    b.sort()
    c = []
    for i in b:
        for j in range(num):
            if j in list(d.keys()):
                if d[j] == i:
                    c.append(a[j])
                    d.pop(j)
    return c

1
投票

如果要保留与原数组长度相同的元素的顺序,请使用冒泡排序。

Input = ["ab","cdc","abcd","de"];

Output  = ["ab","cd","cdc","abcd"]

功能:

function bubbleSort(strArray){
  const arrayLength = Object.keys(strArray).length;
    var swapp;
    var newLen = arrayLength-1;
    var sortedStrArrByLenght=strArray;
    do {
        swapp = false;
        for (var i=0; i < newLen; i++)
        {
            if (sortedStrArrByLenght[i].length > sortedStrArrByLenght[i+1].length)
            {
               var temp = sortedStrArrByLenght[i];
               sortedStrArrByLenght[i] = sortedStrArrByLenght[i+1];
               sortedStrArrByLenght[i+1] = temp;
               swapp = true;
            }
        }
        newLen--;
    } while (swap);
  return sortedStrArrByLenght;
}

1
投票
let arr  = [5,2,100,1,20,3];
arr.sort((a,b)=>{
  return a-b 
})

console.log(arr) //[1, 2, 3, 5, 20, 100]

在返回值上,排序方法将执行元素交换的功能

return < 0  { i.e -ve number then  a comes before b}
return > 0  { i.e +ve number then  b comes before a}
return == 0 { order of a and b remains same }

0
投票

根据 Salman 的回答,我编写了一个小函数来封装它:

function sortArrayByLength(arr, ascYN) {
        arr.sort(function (a, b) {           // sort array by length of text
            if (ascYN) return a.length - b.length;              // ASC -> a - b
            else return b.length - a.length;                    // DESC -> b - a
        });
    }

然后用

调用它
sortArrayByLength( myArray, true );

请注意,不幸的是,函数可以/不应该添加到数组原型中,如本页所述。

此外,它修改了作为参数传递的数组,并且不返回任何内容。这将强制数组重复,并且对于大型数组来说并不是很好。如果有人有更好的想法,请评论!


0
投票

我改编了@shareef的答案以使其简洁。我用,

.sort(function(arg1, arg2) { return arg1.length - arg2.length })


0
投票

这段代码应该可以解决问题:

var array = ["ab", "abcdefgh", "abcd"];

array.sort(function(a, b){return b.length - a.length});

console.log(JSON.stringify(array, null, '\t'));

0
投票
let array = [`ab`, `abcdefgh`, `abcd`];
let newArray = array.sort((a,b) => {
    return b.length - a.length
})
console.log(newArray);

请输入以下代码


-3
投票
<script>
         arr = []
         arr[0] = "ab"
         arr[1] = "abcdefgh"
         arr[2] = "sdfds"
         arr.sort(function(a,b){
            return a.length<b.length
         })
         document.write(arr)

</script>

您传递给 sort 的匿名函数告诉它如何对给定的数组进行排序。希望这会有所帮助。我知道这很令人困惑,但您可以通过将函数作为参数传递给排序函数来告诉它如何对数组的元素进行排序告诉它做什么

© www.soinside.com 2019 - 2024. All rights reserved.