JS常见数组排序方法

简介: JS常见数组排序方法

排序方法


(一)//原生双重for循环排序 (冒泡排序)


       for (let i = 0; i < arr.length; i++) {
            for (let z = 0; z < arr.length; z++) {
                if (arr[i] < arr[z]) {
                    [arr[i], arr[z]] = [arr[z], arr[i]]
                }
            }
        }
        console.log(arr);


(二)原生利用对象


    let newarr = []
        let obj = {}//创建空对象
        //给空对象一个初始键
        arr.forEach(function (item) {
            obj[item] = 0
        })
        //{4: 0, 6: 0, 8: 0, 10: 0, 20: 0, 29: 0}
        //判断每一项有几个数小于它  小于它的项最多的就是最大项
        for (let i = 0; i < arr.length; i++) {
            arr.forEach(function (item) {
                if (arr[i] > item) {
                    obj[arr[i]]++
                }
            })
        }
        console.log(obj);//{4: 0, 6: 1, 8: 2, 10: 3, 20: 4, 29: 5}
        //最大的项,有五个数小于它
        for (const key in obj) {
            newarr[obj[key]] = key
        }//新数组的第0项目也就是最小的项,就是有0个数小于他的项
       console.log(newarr);


(三)sort()方法


console.log(arr.sort(function(a,b){
      return a-b
    }));


(四) 参考插入排序


 let arr = [10, 20, 6, 8, 29, 4]
        //参考 插入排序
        //从第一个元素开始,该元素可以被认为已经被排序
        // 取出下一个元素,在已经排好序的序列中从后往前扫描
        // 直到找到大于该元素的位置
        let newarr = []
        newarr.push(arr[0])//把第一项放过去  [10]
        for (let i = 1; i < arr.length; i++) {
            let j = 0//每一次都从第一项比起
            while (arr[i] > newarr[j]) {//arr里面的项去newarr从前到后比大小
                j++
            }
            newarr.splice(j, 0, arr[i])
        }//从前往后面找,找到大于自己的项,把自己放在它前面  没找到的话,说明它自己是最大的,值也没有改变就是设置的0,把它放到第0项即可.
        console.log(newarr);


(五)选择排序


每次找到最小的,放在最前面,然后外层循环加一,因为最小的已经不需要找了,再找第二小的放在最前面.每一次把第i项当成默认的最小项,也就是从第i项开始查找,因为i项之前的都已经排好了,最后交换位置,即把最小的交换到i的位置.也就是递增


let arr = [10, 20, 6, 8, 29, 4]
        for (let i = 0; i < arr.length - 1; i++) {
            let mindex = i;//用于储存最小值的下标,排序刚开始时,假设最小值的下标就是选中的基准数据下标
            for (let j = i + 1; j < arr.length; j++) {
                if (arr[j] < arr[mindex]) {
                    mindex = j
                }
            }
            [arr[i], arr[mindex]] = [arr[mindex], arr[i]]
        }
        console.log(arr);

目录
打赏
0
0
0
0
1
分享
相关文章
有哪些有效的方法可以优化Node.js应用的性能?
有哪些有效的方法可以优化Node.js应用的性能?
188 69
Debian 11系统下Node.js版本更新方法详解
本指南详细介绍在Linux系统中安装和管理Node.js的步骤。首先检查现有环境,包括查看当前版本和清除旧版本;接着通过NodeSource仓库安装最新版Node.js并验证安装结果。推荐使用nvm(Node Version Manager)进行多版本管理,便于切换和设置默认版本。同时,提供常见问题解决方法,如权限错误处理和全局模块迁移方案,以及版本回滚操作,确保用户能够灵活应对不同需求。
116 0
Debian 11系统下Node.js版本更新方法
Debian 11更新Node.js主要就是这三种方式,无论你是初涉其中的新手还是找寻挑战的专家,总有一种方式能满足你的需求。现在,你已经是这个
181 80
前端原生Js批量修改页面元素属性的2个方法
原生 Js 的 getElementsByClassName 和 querySelectorAll 都能获取批量的页面元素,但是它们之间有些细微的差别,稍不注意,就很容易弄错!
149 1
有没有方法可以保证在JavaScript中多个异步操作的执行顺序?
有没有方法可以保证在JavaScript中多个异步操作的执行顺序?
145 58
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
深入理解 JavaScript 中的 Array.find() 方法:原理、性能优势与实用案例详解
Array.find() 是 JavaScript 数组方法中一个非常实用和强大的工具。它不仅提供了简洁的查找操作,还具有性能上的独特优势:返回的引用能够直接影响原数组的数据内容,使得数据更新更加高效。通过各种场景的展示,我们可以看到 Array.find() 在更新、条件查找和嵌套结构查找等场景中的广泛应用。 在实际开发中,掌握 Array.find() 的特性和使用技巧,可以让代码更加简洁高效,特别是在需要直接修改原数据内容的情形。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一
通过array.some()实现权限检查、表单验证、库存管理、内容审查和数据处理;js数组元素检查的方法,some()的使用详解,array.some与array.every的区别(附实际应用代码)
array.some()可以用来权限检查、表单验证、库存管理、内容审查和数据处理等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
通过array.every()实现数据验证、权限检查和一致性检查;js数组元素检查的方法,every()的使用详解,array.some与array.every的区别(附实际应用代码)
array.every()可以用来数据验证、权限检查、一致性检查等数据校验工作,核心在于利用其短路机制,速度更快,节约性能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问