`

第四课 插入排序

阅读更多
引用
笔记--插入排序

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语言实现的插入排序

    插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。本文将深入探讨C语言实现的插入排序及其相关知识点。 首先,理解插入排序...

    插入排序Java代码

    #### 四、插入排序的时间复杂度 - **最好情况**:当输入数组已经是有序的情况下,插入排序的时间复杂度为O(n),此时只需要进行一次比较即可确定当前位置。 - **平均情况**:时间复杂度为O(n^2),这是因为对于每个...

    使用分治法的插入排序

    **插入排序**是一种基础且广泛使用的排序算法,尤其在数据量较小或者部分有序的情况下表现出较高的效率。它基于分治法的思想,将一个大问题分解成若干小问题来解决。在这个场景中,我们讨论的是如何使用分治法的思想...

    大学生实验排序 泡泡排序 直接插入排序 折半插入排序 希尔排序 直接选择排序 统计时间 比较次数和交换次数 保存为txt文件

    4. **希尔排序**:希尔排序是插入排序的一种更高效的版本,通过将数组分为若干个子序列,然后对每个子序列进行插入排序,逐步减少子序列的间隔,直至间隔为1,最后进行一次插入排序。这种方法减少了元素的移动次数,...

    C++实现插入排序

    根据给定的文件信息,我们可以总结出以下关于“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 #...

    java实现插入排序

    插入排序是一种简单的排序算法,它的基本思想是将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。在Java中实现插入排序,主要涉及数组操作和循环控制,我们可以从以下几个方面来理解这...

    冒泡排序,选择排序,插入排序,希尔排序,堆排序,归并排序,快速排序源码实现

    4. **希尔排序**:希尔排序是插入排序的一种更高效的改进版本,也称为缩小增量排序。它通过设置间隔序列,将待排序的数组分组,然后对每组进行插入排序,逐渐减少间隔,直到间隔为1,整个序列变得有序。源码中,会...

    完整详细版Python全套教学课件 第04-A节 插入排序.pptx

    Python 插入排序算法详解 Python 的插入排序算法是一种简单而高效的排序算法,旨在对...第四趟:哨兵为 8,比较 5 和哨兵,5 小,哨兵插入,本轮比较结束。 以此类推,直至把最后一个数字放到哨兵并比较、插入完成。

    冒泡排序、选择排序、插入排序

    冒泡排序、选择排序和插入排序是三种基本的排序算法,它们都是在计算机科学中用于组织数据的关键技术。这些算法的实现通常用作教学示例,帮助初学者理解排序过程和时间复杂性。 **冒泡排序(Bubble Sort)**: 冒泡...

    《数据结构》折半插入排序

    折半插入排序(Binary Insertion Sort)是该书中介绍的一种基本排序算法,它是对传统插入排序的一种优化。本文将详细阐述折半插入排序的原理、步骤以及在实际应用中的优势和局限性。 折半插入排序是一种基于比较的...

    快速排序,堆排序,归并排序,插入排序,选择排序

    4. **插入排序**: 插入排序是一种简单直观的排序算法,将数组分为已排序部分和未排序部分,每次将一个未排序元素插入到已排序部分的正确位置。对于小规模或部分有序的数组,插入排序表现良好,时间复杂度为O(n^2)。...

    快速插入排序的C语言实现

    快速排序和插入排序是两种广泛使用的排序算法,它们在计算机科学和编程中具有重要的地位。本文将详细讨论这两种排序算法的原理、实现以及如何结合它们的优点以提高排序效率。 快速排序是一种高效的比较型排序算法,...

Global site tag (gtag.js) - Google Analytics