当前位置: 首页 > news >正文

雍鑫建设集团网站网页设计电子版教材

雍鑫建设集团网站,网页设计电子版教材,wordpress get_most_viewed,网站大全免费完整版一、插入排序 插入排序是一种简单直观的排序算法。它的原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。 #mermaid-svg-v2YbPqchr8qWCPvn {font-family:"trebuchet ms",verdana,arial,san…

一、插入排序

插入排序是一种简单直观的排序算法。它的原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。

有元素
无元素
无元素
初始数组
未排序区间
选择一个待插入元素
已排序区间
插入元素到已排序区间
重新确定未排序区间
排序完成

这个流程图描述了插入排序的过程。初始数组经过选择一个待插入元素的步骤,并判断是否有元素。如果有元素,则将它插入到已排序区间,并重新确定未排序区间。如果没有元素,则排序完成。

js实现:

function insertionSort(arr) {// 循环每个元素,从第二个元素开始for (let i = 1; i < arr.length; i++) {// 当前元素let current = arr[i];// 设置当前元素的前一个元素的下标let j = i - 1;// 当前元素与它前面的元素比较,如果前面的元素较大,则向右移动while (j >= 0 && arr[j] > current) {arr[j + 1] = arr[j];j--;}// 将当前元素插入到正确的位置arr[j + 1] = current;}// 返回排序后的数组return arr;
}let array = [5, 3, 8, 2, 1, 4];
console.log(insertionSort(array));  // 输出:[1, 2, 3, 4, 5, 8]

这里使用插入排序算法对数组 [5, 3, 8, 2, 1, 4] 进行排序。首先,第一个元素 5 被标记为已排序序列,从第二个元素开始,依次与已排序序列中的元素比较,找到合适的位置插入。在每一轮循环中,当前元素会与已排序序列中的元素从后向前依次比较,直到找到插入位置。

初始数组:[8, 3, 5, 1, 4]

插入元素过程描述排序后的数组
8初始状态[8, 3, 5, 1, 4]
3将3插入到前面比它大的数之前[3, 8, 5, 1, 4]
5将5插入到前面比它大的数之前[3, 5, 8, 1, 4]
1将1插入到前面比它大的数之前[1, 3, 5, 8, 4]
4将4插入到前面比它大的数之前[1, 3, 4, 5, 8]

最终排序结果:[1, 3, 4, 5, 8]

插入排序的过程可以类比现实生活中整理扑克牌的过程。初始时,我们手里有一摞乱序的扑克牌。我们从第二张牌开始,将其与前面的牌依次比较,找到合适的位置插入。重复这个过程,直到所有的牌都被按照顺序放置在手上。每次比较时,左手持有的牌都是已排序的,右手持有的牌都是未排序的。这个过程就是插入排序的模拟。

二、使用二分法优化插入排序

可以使用二分法优化上述插入排序算法。二分法优化的思想是将插入排序中的线性查找部分改为二分查找,从而减少比较的次数,提高排序效率。

以下是使用二分法优化的插入排序算法:

function insertionSort(arr) {for (let i = 1; i < arr.length; i++) {let current = arr[i];let left = 0; // 排序部分的起始位置let right = i - 1; // 排序部分的结束位置// 使用二分查找找到插入位置while (left <= right) {let mid = Math.floor((left + right) / 2);if (arr[mid] > current) {right = mid - 1;} else {left = mid + 1;}}// 将大于current的元素右移for (let j = i - 1; j >= left; j--) {arr[j + 1] = arr[j];}// 插入到正确的位置arr[left] = current;}return arr;
}

使用二分法优化后,排序效率会有所提高,但在数据量较小时可能没有明显的优势。因此,在实际应用中需要根据具体情况选择是否使用二分法优化。

http://www.yayakq.cn/news/486168/

相关文章:

  • 龙岗网站建设费用平面设计与网页设计
  • 简述网站开发建设的基本流程昆山公司网站建设电话
  • 长沙免费网站排名有哪些可以做兼职的翻译网站吗
  • 网站建设的目标是什么 提供了哪些栏目想卖产品怎么推广宣传
  • 电商网站首页字体温州网站开发app制作
  • 建立网站邮箱附近男科医院在哪里
  • 申请一个网站需要怎么做wordpress meta slider
  • 网站开发实验报告三购买域名后用wordpress建站
  • 企业网站设计服务公司高水平的大连网站建设
  • 特产网站建设策划书微信小程序开发实战课后答案
  • 长沙门户网站上海短期网站建设培训
  • photoshop网站模板设计教程视频凡科快速建站
  • 章丘环保网站建设 中企动力西安整站优化
  • 住房和城乡建设部官网证件查询注册知了seo
  • 宁波营销网站建设网站建设 价格
  • fullpage网站怎么做网站后台难做么
  • 建设银行业务管理中心网站商标注册收费标准
  • 南京定制网站建设怎么收费希爱力
  • 做传销网站违法的吗湖南网站seo推广
  • 贵阳网站建设运营做钢材的都用什么网站
  • 怎么做企业官方网站自媒体营销的策略和方法
  • 网站英语培训班哪个机构好做外贸网站价位
  • 邢台好蜘蛛网站建设沈阳关键词seo排名
  • 苏州网站建立公司wordpress 建立导航
  • 国内网站设计制作设计一个企业官网的栏目
  • 网站建设与运营考试成都百度推广公司电话
  • 邗江区网站建设套餐iis网站出乱码
  • 单页网站模板修改吗wordpress 优化版本
  • 响应式网站开发案例aso优化师
  • 温州专门做网站廊坊网站建设方案最新报价