直接插入排序算法:ArrayList实现和数组实现

转载请注明出处,谢谢!

直接插入排序算法思想:

  • 排序区间R[1..n]
  • 在排序的过程中,整个排序区间被分为两个子区间: 有序区R[ 1 ... i-1 ]和无序区R[ i ... n ]
  • 共进行n-1趟排序,每趟排序都是把无序区的第一条记录Ri插到有序区的合适位置上。

插入排序

  • 直接插入排序
  • 折半插入排序
  • 二路插入排序
  • 希尔排序

算法说明

  • 对于随机排列的长度为\(N\)且主键不重复的数组:
    • 平均情况下需要\(~\frac{N^2}{4}\)次比较及\(~\frac{N^2}{4}\)次交换。
    • 最坏情况下需要\(~\frac{N^2}{2}\)次比较及\(~\frac{N^2}{2}\)次交换。
    • 最好情况下需要\(N-1\)次比较及\(0\)次交换。
  • 适用环境:
    * 适用于少量元素,且几乎有序的序列。

ArrayList实现:

import java.util.ArrayList;
import java.util.Random;

public class Charupaixu {

ArrayList<Integer> al;

public Charupaixu(int num, int bound) {
    al = new ArrayList<>(num);
    // 创建一个随机数生成器
    Random rand = new Random();
    // 添加1-100的随机整数
    for (int i = 0; i < num; i++) {
        al.add(new Integer(Math.abs(rand.nextInt(bound))+1));
    }
    System.out.println("The ArrayList Sort Before:\n" + al);
}

public void ZJCRSortIt() {
    System.out.println("Sorting :");
    Integer tempInt;

    for (int i = 1; i < al.size(); i++) {
        // 将a[i]插入到a[i-1] a[i-2] a[i-3] ... 中
        for (int j = i; j > 0 && (al.get(j) < al.get(j - 1)); j--) {
            tempInt = al.remove(j);
            al.add(j - 1, tempInt);
            System.out.println(al);
        }
    }
}

public static void main(String[] args) {
    Charupaixu cr = new Charupaixu(10, 100);
    cr.ZJCRSortIt();
}

}

Output:

The ArrayList Sort Before:
[10, 75, 61, 50, 17, 60, 19, 7, 73, 87]
Sorting :
[10, 75, 61, 50, 17, 60, 19, 7, 73, 87]
[10, 61, 75, 50, 17, 60, 19, 7, 73, 87]
[10, 50, 61, 75, 17, 60, 19, 7, 73, 87]
[10, 17, 50, 61, 75, 60, 19, 7, 73, 87]
[10, 17, 50, 60, 61, 75, 19, 7, 73, 87]
[10, 17, 19, 50, 60, 61, 75, 7, 73, 87]
[7, 10, 17, 19, 50, 60, 61, 75, 73, 87]
[7, 10, 17, 19, 50, 60, 61, 73, 75, 87]
[7, 10, 17, 19, 50, 60, 61, 73, 75, 87]

数组实现:

int[] a={ 50, 15, 18, 8, 40, 51, 60, 1, 1, 20, 15 };
        System.out.println("The ArrayList Before Sort is:");
        for (int k = 0; k < a.length; k++) {
            System.out.print(a[k]+", ");
        }

        System.out.println("\nSorting:");
        
        for(int i = 1;i<a.length;i++){
            
            int temp = a[i];
            int j;
            
            for (j = i; (j >0) && (a[j-1] > temp); j--) {
                a[j]=a[j-1];
            }
            
            a[j]=temp;
            
            for (int k = 0; k < a.length; k++) {
                System.out.print(a[k]+", ");
            }
            
            System.out.println();
        }
        
        
Output:

The ArrayList Before Sort is:
50, 15, 18, 8, 40, 51, 60, 1, 1, 20, 15, 
Sorting:
15, 50, 18, 8, 40, 51, 60, 1, 1, 20, 15, 
15, 18, 50, 8, 40, 51, 60, 1, 1, 20, 15, 
8, 15, 18, 50, 40, 51, 60, 1, 1, 20, 15, 
8, 15, 18, 40, 50, 51, 60, 1, 1, 20, 15, 
8, 15, 18, 40, 50, 51, 60, 1, 1, 20, 15, 
8, 15, 18, 40, 50, 51, 60, 1, 1, 20, 15, 
1, 8, 15, 18, 40, 50, 51, 60, 1, 20, 15, 
1, 1, 8, 15, 18, 40, 50, 51, 60, 20, 15, 
1, 1, 8, 15, 18, 20, 40, 50, 51, 60, 15, 
1, 1, 8, 15, 15, 18, 20, 40, 50, 51, 60, 


——@guoyangde http://www.cnblogs.com/LittleTreasureBox/p/8904016.html

转载于:https://www.cnblogs.com/LittleTreasureBox/p/8904016.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值