热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

关于冒泡排序、选择排序、快速排序的一些见解。

1、冒泡排序:functionmaopao(arr){vartemp;for(i0;i
1、冒泡排序:
function maopao(arr) {
  var temp;
  for (i = 0; i
    for (j = 0; j
      if (arr[j] > arr[j + 1]) {
        temp = arr[j + 1];
        arr[j + 1] = arr[j];
        arr[j] = temp;
      }
    }
  }
  return arr;
}
var arr = [10, 209, 30, 4, 57]
console.log(maopao(arr));
 
冒泡排序使用的逻辑是两两进行比较,先选出最后一位,然后在外围循环第二轮开始之后,对比继续从下标为0的值开始两两比较,继续选出当前循环的最大值,依次类推。因为下标的最大值是arr.length-1,所以,外面的循环次数是下标的长度。在第一轮结束之后,第二轮照样是从下标为0的值开始对比,因此内循环的初始值为0,在i进行了增加之后,还想像原来一样的模式循环,则需要减去每次添加的i,内部外部双管齐下,一步步排除每次循环的最值,最后得出结果
 
2、选择排序:
function xuanze(arr) {
  var temp;
  for (i = 0; i
    for (j = i + 1; j
      if (arr[i] > arr[j]) {
        temp = arr[j];
        arr[j] = arr[i];
        arr[i] = temp;
      }
    }
  }
  return arr;
}
var arr = [19, 3, 4, 324, 6, 45]
console.log(xuanze(arr));
 
选择排序又叫打擂台,是将每一轮最靠前的下标的值与其它位置的值进行对比,因此内部循环的初始下标为i+1,因为在对比的时候,不会和自己进行比较,没有意义。每个小循环将当前数组内最靠前的下标的值与其它值进行对比,若符合条件则交换位置,因此每轮小循环都会选出当前的排第一的值,在选出第一之后,下面的循环没有必要将他再与其它值进行比较,因此外层循环确定的是每个大循环的确认下标的位置,内循环则是从他的+1的位置开始向后进行比较。最初的时候是所有的值进行比较,依次类推,因此可以将所有轮循环的下标为0的值进行剔除,内循环的上限是数组的长度。
 
3、快速排序
function quickly(arr) {
  if (arr.length <2) {
    return arr;
  }
  var left = [];
  var right = [];
  var mid;
  if (arr.length % 2 != 0) {
    mid = (arr.length + 1) / 2;
  } else {
      mid = arr.length / 2;
  }
  var leg = arr[mid];
  for (var i = 0; i
    if (arr[i]
      left.push(arr[i]);
    } else if (arr[i] >= arr[mid] && mid != i) {
      right.push(arr[i])
    }
  }
  return quickly(left).concat(leg).concat(quickly(right));
}
var arr = [12, 3, 45, 6, 3, 5, 6]
console.log(quickly(arr));
 
快速排序是从中间划分大小,大小分开两边,建立两个单独的数组,然后在单独的数组中进行递归,使每个数都被单独分开,最后将左中右三部分进行拼接导出最终的数据。递归停止的条件是每个数都单独被划分出来,也就是函数内数组的长度小于2。在确定中间值的时候,为了防止是奇数造成漏洞,可以先去判断当前数组的个数,若是奇数则进行(+1)/2的操作,确保中间值肯定是整数,接着利用循环将当前数组继续分为左右两个数组,依次类推。为了确保不会出现重复,循环里边的判断条件需要加一句中间值不等于当前的下标值。

关于冒泡排序、选择排序、快速排序的一些见解。


推荐阅读
  • 解决Bootstrap DataTable Ajax请求重复问题
    在最近的一个项目中,我们使用了JQuery DataTable进行数据展示,虽然使用起来非常方便,但在测试过程中发现了一个问题:当查询条件改变时,有时查询结果的数据不正确。通过FireBug调试发现,点击搜索按钮时,会发送两次Ajax请求,一次是原条件的请求,一次是新条件的请求。 ... [详细]
  • 本文介绍了 AngularJS 中的 $compile 服务及其用法,通过示例代码展示了如何使用 $compile 动态编译和链接 HTML 元素。 ... [详细]
  • 本文介绍了如何在 ASP.NET 中设置 Excel 单元格格式为文本,获取多个单元格区域并作为表头,以及进行单元格合并、赋值、格式设置等操作。 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • ZooKeeper 入门指南
    本文将详细介绍ZooKeeper的工作机制、特点、数据结构以及常见的应用场景,包括统一命名服务、统一配置管理、统一集群管理、服务器动态上下线和软负载均衡。 ... [详细]
  • 数字资产量化交易通过大数据分析,以客观的方式制定交易决策,有效减少人为的主观判断和情绪影响。本文介绍了几种常见的数字资产量化交易策略,包括搬砖套利和趋势交易,并探讨了量化交易软件的开发前景。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • importpymysql#一、直接连接mysql数据库'''coonpymysql.connect(host'192.168.*.*',u ... [详细]
  • 微软推出Windows Terminal Preview v0.10
    微软近期发布了Windows Terminal Preview v0.10,用户可以在微软商店或GitHub上获取这一更新。该版本在2月份发布的v0.9基础上,新增了鼠标输入和复制Pane等功能。 ... [详细]
  • Framework7:构建跨平台移动应用的高效框架
    Framework7 是一个开源免费的框架,适用于开发混合移动应用(原生与HTML混合)或iOS&Android风格的Web应用。此外,它还可以作为原型开发工具,帮助开发者快速创建应用原型。 ... [详细]
  • 本文介绍了如何使用 CMD 批处理脚本进行文件操作,包括将指定目录下的 PHP 文件重命名为 HTML 文件,并将这些文件复制到另一个目录。 ... [详细]
  • 两个条件,组合控制#if($query_string~*modviewthread&t(&extra(.*)))?$)#{#set$itid$1;#rewrite^ ... [详细]
  • 本文详细介绍了DMA控制器如何通过映射表处理来自外设的请求,包括映射表的设计和实现方法。 ... [详细]
author-avatar
尚庆湃
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有