引用
笔记--插入排序
1.插入排序类
package com.flysnow.chap03;
/**
* 插入排序
* @author 飞雪无情
* @since:2010-3-25
*/
public class ArrayInsert {
private long[] a;
private int nElems;
public ArrayInsert(int max){
a=new long[max];
nElems=0;
}
/**
* 插入元素
* @param value
*/
public void insert(long value){
a[nElems]=value;
nElems++;
}
/**
* 打印元素
*/
public void display(){
for(int i=0;i<nElems;i++){
System.out.print(a[i]+" ");
}
System.out.println();
}
/**
* 插入排序排序
*/
public void insertionSort(){//比较次数O(N^2),但是复制比交换的时间要少。比冒泡快一倍,比插入略快
int out,in;
for(out=0;out<nElems;out++){
long temp=a[out];//标记
in=out;
while(in>0&&a[in-1]>=temp){//大于标记值右移
a[in]=a[in-1];
--in;
}
a[in]=temp;
}
}
}
2.插入排序测试
package com.flysnow.chap03;
import java.util.Random;
/**
* 插入排序测试
* @author 飞雪无情
* @since:2010-3-25
*/
public class InsertSortApp {
public static void main(String[] args){
ArrayInsert insert=new ArrayInsert(100);
Random random=new Random();
for(int i=0;i<20;i++){//添加20个随机数
insert.insert((long)(random.nextFloat()*100));
}
insert.display();//未排序
insert.insertionSort();//排序
insert.display();//排序后
}
}
3.总结
算法思想:
- 选择第二个(1号)数据为标记,和其前面的数据(0号)比较,如果1号数据小于0,则0号后移变成1号,而原来的1号数据占据原来的0号位置。
- 选择第三个(2号)数据位标记,和其前面的数据(0号,1号)循环比较,如果前面的数据比标记大,则该数据后移。
- 依次类推,直到完成排序。。循环条件就是下标大于0并且前面的数据大于等于标记值。
- 描述: 插入排序
- 大小: 39.9 KB
- 描述: 几种简单算法的比较
- 大小: 70.9 KB
分享到:
相关推荐
### 插入排序详解 #### 一、插入排序概述 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上通常采用in-...
插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。本文将深入探讨C语言实现的插入排序及其相关知识点。 首先,理解插入排序...
#### 四、插入排序的时间复杂度 - **最好情况**:当输入数组已经是有序的情况下,插入排序的时间复杂度为O(n),此时只需要进行一次比较即可确定当前位置。 - **平均情况**:时间复杂度为O(n^2),这是因为对于每个...
**插入排序**是一种基础且广泛使用的排序算法,尤其在数据量较小或者部分有序的情况下表现出较高的效率。它基于分治法的思想,将一个大问题分解成若干小问题来解决。在这个场景中,我们讨论的是如何使用分治法的思想...
4. **希尔排序**:希尔排序是插入排序的一种更高效的版本,通过将数组分为若干个子序列,然后对每个子序列进行插入排序,逐步减少子序列的间隔,直至间隔为1,最后进行一次插入排序。这种方法减少了元素的移动次数,...
根据给定的文件信息,我们可以总结出以下关于“C++实现插入排序”的相关知识点: ### 一、插入排序算法概述 插入排序(Insertion Sort)是一种简单直观的比较排序算法。它的工作原理是通过构建有序序列,对于未...
### 数据结构之直接插入排序详解 #### 一、引言 在计算机科学中,排序算法是数据处理中不可或缺的一部分,而直接插入排序是一种简单直观的排序方法。它的工作原理类似于我们手动排序一组卡片的方式——每次从未...
4. **最终排序**:当增量`h`减小到1时,对整个序列进行一次插入排序。 #### C语言实现示例 在提供的代码片段中,希尔排序的实现方法如下: ```c void ShellInsert(SqList *L) { // ...代码省略... int dk = b[k];...
根据提供的文件信息,我们可以深入探讨几种经典的排序算法:冒泡排序、直接插入排序、快速排序以及希尔排序。这些算法在数据结构与算法课程中是非常重要的基础内容,它们各自有着独特的特性和应用场景。 ### 1. ...
4. **折半插入排序的空间复杂度分析** 5. **折半插入排序与普通插入排序的区别** 6. **折半插入排序的应用场景** 7. **C语言实现** #### 折半插入排序的基本概念 折半插入排序是插入排序的一种变种,它在插入排序的...
直接插入排序是一种基础的排序算法,它的工作原理是将未排序的元素逐个与已排序的部分进行比较,找到合适的位置并插入。而“二分法直接插入排序”则是对传统直接插入排序的一种优化,它利用了二分查找的特性来减少在...
#### 四、直接插入排序的实现代码 下面是一段用 C 语言编写的直接插入排序的示例代码,这段代码定义了一个 `SortObject` 结构体来表示待排序的对象,并提供了一个 `insertSort` 函数来进行排序。 ```c #include #...
插入排序是一种简单的排序算法,它的基本思想是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。在Java中实现插入排序,主要涉及数组操作和循环控制,我们可以从以下几个方面来理解这...
4. **希尔排序**:希尔排序是插入排序的一种更高效的改进版本,也称为缩小增量排序。它通过设置间隔序列,将待排序的数组分组,然后对每组进行插入排序,逐渐减少间隔,直到间隔为1,整个序列变得有序。源码中,会...
Python 插入排序算法详解 Python 的插入排序算法是一种简单而高效的排序算法,旨在对...第四趟:哨兵为 8,比较 5 和哨兵,5 小,哨兵插入,本轮比较结束。 以此类推,直至把最后一个数字放到哨兵并比较、插入完成。
冒泡排序、选择排序和插入排序是三种基本的排序算法,它们都是在计算机科学中用于组织数据的关键技术。这些算法的实现通常用作教学示例,帮助初学者理解排序过程和时间复杂性。 **冒泡排序(Bubble Sort)**: 冒泡...
折半插入排序(Binary Insertion Sort)是该书中介绍的一种基本排序算法,它是对传统插入排序的一种优化。本文将详细阐述折半插入排序的原理、步骤以及在实际应用中的优势和局限性。 折半插入排序是一种基于比较的...
4. **插入排序**: 插入排序是一种简单直观的排序算法,将数组分为已排序部分和未排序部分,每次将一个未排序元素插入到已排序部分的正确位置。对于小规模或部分有序的数组,插入排序表现良好,时间复杂度为O(n^2)。...
快速排序和插入排序是两种广泛使用的排序算法,它们在计算机科学和编程中具有重要的地位。本文将详细讨论这两种排序算法的原理、实现以及如何结合它们的优点以提高排序效率。 快速排序是一种高效的比较型排序算法,...