`
128kj
  • 浏览: 600410 次
  • 来自: ...
社区版块
存档分类
最新评论

插入排序(JAVA)

 
阅读更多
网上的代码太多了,找些易理解的。
我们把数组分为已排序和未排序两部分,把未排序的元素一次一个插入到已排序部分的合适位置上。已排序部分逐渐增大,直到整个数组变成有序的。
下面通过一个例子来说明这个排序流程:
      待排序列:   49, 38 , 65 , 97, 76 , 13, 27 ,49

       插入49:   49

       插入38:   38, 49

       插入65:   38, 49,  65

       插入97:   38, 49,  65,  97

       插入76:   38, 49,  65,  76,  97

       插入13:   13, 38,  49,  65,  76,  97

       插入27:   13, 27,  38,  49,  65,  76, 97

       插入49:   13, 27,  38,  49,  49,  65, 76, 97

   大家想想在排队时,要把个子矮的人调整到适当的位置,都是和他前面的比较,如果比他前面的人矮,就插入到前面去,直到他前面的人都比他个子矮,这样最后就可以形成一个有序的队伍。下面是代码:

public class InsertSort {

    public static void main(String[] args) {
    int[] array = {10,-3,5,34,-34,5,0,9};   
    sort(array);
    for(int el : array) {
        System.out.print(el + " ");
    }
    }
    
    static void sort(int[] array) {
    int temp;
    int i,j;
    int length = array.length;
        
    for(i = 1; i < length; i++) {
        temp = array[i];
        for(j = i-1; j >=0; j--) {
        if(temp < array[j]) {
            array[j+1] = array[j];
        } else {
            break;
        }
        }
        array[j+1] = temp;
    }
    }
}




排序过程:
-3 10 5 34 -34 5 0 9
-3 5 10 34 -34 5 0 9
-3 5 10 34 -34 5 0 9
-34 -3 5 10 34 5 0 9
-34 -3 5 5 10 34 0 9
-34 -3 0 5 5 10 34 9
-34 -3 0 5 5 9 10 34

下载源码:
分享到:
评论

相关推荐

    插入排序Java代码

    ### 插入排序Java代码详解 #### 一、插入排序简介 插入排序是一种简单直观的排序算法。它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,...

    直接插入排序java源码

    直接插入排序 java实现~你值得拥有~

    插入排序 java实现

    在Java中实现插入排序,主要涉及以下几个关键步骤: 1. **初始化**:创建一个方法,如`public static void insertionSort(int[] arr)`,接收一个整数数组作为参数。 2. **外层循环**:遍历数组,从第二个元素...

    java实现插入排序

    在Java中实现插入排序,主要涉及数组操作和循环控制,我们可以从以下几个方面来理解这个过程。 1. **基本概念** 插入排序在实际操作中类似于打扑克牌,每拿到一张新牌(数组中的元素),就将其插入到已排序的序列...

    插入排序java

    插入排序java

    插入排序法JAVA代码

    在Java中实现插入排序,我们可以创建一个名为`insertionSort`的方法,接受一个整数数组作为参数。这个方法通过两个嵌套的循环来完成排序。外层循环遍历数组中的每个元素,内层循环则用于找到当前元素的正确位置并将...

    插入排序的Java代码实现

    本文将详细讲解插入排序的概念、原理,并提供一个Java语言的实现示例。 插入排序是一种基本的排序算法,它的工作原理类似于我们平时整理扑克牌的过程。想象一下,你有一堆未排序的牌,每次取出一张牌,将其插入到已...

    JAVA实现插入排序

    JAVA实现插入排序,简单演示

    Java直接插入排序算法源码

    总的来说,Java中的直接插入排序算法是一个直观易懂的排序方法,虽然在效率上不敌更高级的排序算法,但它在理解和实现上相对简单,对于初学者来说是很好的学习材料。通过阅读和实践这个源代码,你可以深入理解排序...

    快速和插入排序

    `test.java`文件可能是用来测试这两种排序算法的代码,它可能包含了主函数,用于创建测试数组,并调用快速排序和插入排序的函数,然后打印排序后的结果,以验证算法的正确性。 总的来说,快速排序通常比插入排序更...

    数组排序 1、冒泡排序 2、选择排序 3、插入排序 4、不同的随机数

    数组排序 1、冒泡排序 2、选择排序 3、插入排序 4、生成不同的随机数并排序

    java 直接插入排序

    下面我们将详细探讨Java实现的直接插入排序算法: 1. **算法步骤** - 初始化:设置一个空的有序序列,将第一个元素视为已排序。 - 遍历:从第二个元素开始遍历数组,将其称为当前元素。 - 比较:将当前元素与已...

    Java实现插入排序

    在Java中实现插入排序,我们可以按照以下步骤进行: 1. **基本思想**:将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增1的有序表。可以想象成每次从无序序列中取出一个元素,找到它在有序序列中...

    冒泡排序、直接插入排序 等java代码

    本文将详细讨论两种常见的简单排序算法:冒泡排序和直接插入排序,它们都是基于比较的内部排序算法,并且在Java语言中实现。 **冒泡排序(Bubble Sort)** 冒泡排序是一种基础的排序算法,其基本思想是通过重复...

    JAVA单链表(多项式)直接插入排序

    JAVA单链表(多项式)直接插入排序 JAVA单链表(多项式)直接插入排序

    java插入排序与合并排序

    本文将深入探讨两种常见的排序算法:插入排序和合并排序,并基于一个长度为200000的数组进行性能比较。 **插入排序**是一种简单直观的排序算法,它的基本思想是通过构建有序序列,对于未排序数据,在已排序序列中从...

    用java实现插入排序InsertSort

    用java实现插入排序InsertSort 用java实现插入排序InsertSort用 java实现插入排序InsertSort

    快排和插入排序

    至于提供的文件`Sort_最新.java`,这可能是包含快速排序和插入排序Java实现的源代码文件。通过阅读和理解这段代码,你可以更深入地了解这两种排序方法的具体实现,并可能学习到一些编程技巧和最佳实践。 总之,快速...

    Java 实现 11 种排序算法

    2. **插入排序**:将未排序的元素逐个插入到已排序的序列中,适合小规模或部分有序的数据。其平均和最坏情况时间复杂度都是O(n²)。 3. **希尔排序**:基于插入排序,通过间隔序列对元素进行排序,减少了元素的比较...

    插入排序和归并排序的实现java

    这里我们将深入探讨两种常见的排序算法:插入排序(Insertion Sort)和归并排序(Merge Sort),它们都是在Java环境下实现的。 **插入排序**是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序...

Global site tag (gtag.js) - Google Analytics