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

asp网站访问量大营销型门户网站建设方案

asp网站访问量大,营销型门户网站建设方案,网页布局的基础,网站建设去哪可接单以下是插入排序的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格: 一、插入排序基础实现 原理 将元素逐个插入到已排序序列的合适位置,逐步构建有序序列。 代码示例 public class InsertionSort {void…

以下是插入排序的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格:
在这里插入图片描述


一、插入排序基础实现

原理

将元素逐个插入到已排序序列的合适位置,逐步构建有序序列。

代码示例
public class InsertionSort {void sort(int[] arr) {int n = arr.length;for (int i = 1; i < n; i++) {int key = arr[i]; // 待插入的元素int j = i - 1;// 将比 key 大的元素后移while (j >= 0 && arr[j] > key) {arr[j + 1] = arr[j];j--;}arr[j + 1] = key; // 插入到正确位置}}
}
复杂度分析
  • 时间复杂度
    • 最坏/平均:O(n²)(逆序或随机数据)。
    • 最好(已有序):O(n)
  • 空间复杂度O(1)
  • 稳定性:稳定(相同值的元素相对顺序不变)。

二、常见变体及代码示例

1. 优化版(减少移动次数)

改进点:通过减少元素移动的次数,优化内层循环。
适用场景:数据接近有序时效率更高。

public class OptimizedInsertionSort {void sort(int[] arr) {int n = arr.length;for (int i = 1; i < n; i++) {int key = arr[i];int j = i - 1;// 找到插入位置后一次性移动元素while (j >= 0 && arr[j] > key) {j--;}// 将 j+1 到 i 的元素后移一位for (int k = i; k > j + 1; k--) {arr[k] = arr[k - 1];}arr[j + 1] = key;}}
}
2. 二分插入排序

改进点:用二分查找确定插入位置,减少比较次数。
适用场景:数据规模较大时,减少比较时间。

public class BinaryInsertionSort {void sort(int[] arr) {int n = arr.length;for (int i = 1; i < n; i++) {int key = arr[i];int left = 0, right = i - 1;// 二分查找插入位置while (left <= right) {int mid = (left + right) / 2;if (arr[mid] > key) {right = mid - 1;} else {left = mid + 1;}}// 移动元素并插入for (int j = i - 1; j >= left; j--) {arr[j + 1] = arr[j];}arr[left] = key;}}
}
3. 递归实现

改进点:用递归替代循环,代码结构更清晰。
适用场景:教学或代码风格偏好递归。

public class RecursiveInsertionSort {void sort(int[] arr, int n) {if (n <= 1) return;sort(arr, n - 1); // 先排序前 n-1 个元素int key = arr[n - 1];int j = n - 2;// 将比 key 大的元素后移while (j >= 0 && arr[j] > key) {arr[j + 1] = arr[j];j--;}arr[j + 1] = key;}
}

三、变体对比表格

变体名称时间复杂度空间复杂度稳定性主要特点适用场景
基础插入排序O(n²)(平均/最坏),
O(n)(最好)
O(1)稳定简单易实现,适合小规模或部分有序数据小数据或接近有序的场景
优化版(减少移动次数)O(n²)(平均/最坏),
O(n)(最好)
O(1)稳定减少内层循环的移动次数数据接近有序时效率提升
二分插入排序O(n²)(平均/最坏),
O(n log n)(比较次数)
O(1)稳定用二分查找减少比较次数数据规模较大时减少比较时间
递归实现O(n²)(所有情况)O(n)稳定递归替代循环,代码结构清晰教学或代码风格偏好递归的场景

四、关键选择原则

  1. 基础场景:优先使用基础实现,因其简单且适用于小规模数据。
  2. 优化需求
    • 接近有序数据:优化版(减少移动次数)可提升效率。
    • 大规模数据:二分插入排序通过减少比较次数优化性能。
  3. 代码风格:递归实现适合教学或偏好函数式编程的场景,但需注意栈空间开销。
  4. 稳定性需求:所有变体均稳定,适用于需要保持元素相对顺序的场景(如排序带键值的记录)。
  5. 极端场景:已排序数据时,基础实现的时间复杂度降至 O(n),是插入排序的优势场景。

通过选择合适的变体,可在特定场景下优化性能或代码可读性,同时保持算法的稳定性。

http://www.dtcms.com/wzjs/834979.html

相关文章:

  • 网站如何上传做一个小程序需要多少钱?
  • 无锡网站设计 众做算命网站犯法吗
  • 游戏发布网网站建设深圳网站建设外包公司排名
  • 天津网站建设是什么流量卡代理平台有哪些
  • 南宁手机平台网站建设wordpress安装windows
  • 老站改版与新建网站郑州企业网站托管公司
  • 网站开发综合实训女儿考试没圈关键词
  • 智慧旅游网站开发与设计中国建设银行官网首页 网站首页
  • 网站开发成本核算及账务处理爱企业查询
  • 建设网站要钱么做网站付钱方式
  • 我做的网站不知道网站怎么办大学生个人网页设计代码
  • 潍坊大型网站建设平台中国产品网企业名录
  • 域名查询网站入口深圳做app网站公司
  • 描述一下网站建设的基本流程图工厂办公室简单装修
  • 门户网站微信服务号建设怎样进行网站推广
  • 商业类网站吴江区建设局网站打不开
  • 有网页源码怎么做网站苏州建设网站找网络公司
  • 网站建设进度说明奥派网站建设
  • 百度做网站多少钱设计一个简单的广告
  • 唐山有制作网站的没优秀网站设计欣赏图片
  • 网站的资讯内容seo企业网络推广培训
  • 网站 版式制作网站哪家便宜
  • 一站式网站建设用途网站一键提交
  • 网站如何快速备案微信网站搭建教程
  • 西安做网站选哪家临淄关键词网站优化首选公司
  • 手机app开发网站模板长春生物新冠疫苗
  • 保险代理人做网站标书制作培训课程
  • 大作业做网站南宁网站忧化
  • 企业网站的功能列表dw软件怎么制作网页
  • 政法门户网站建设情况wordpress导航