前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >排序算法之插入排序-java版

排序算法之插入排序-java版

作者头像
shengjk1
发布2020-04-13 11:46:37
4190
发布2020-04-13 11:46:37
举报
文章被收录于专栏:码字搬砖码字搬砖

1. 插入排序

1.1 插入排序的基本介绍

插入排序属于内排,就是以插入的方式来达到排序的目的

1.2 插入排序思想

将待排序的数组看成一个有序列表和一个无序列表。刚开始时有序列表只有一个元素 arr[0],无序列表有n-2 的数据 arr[1] ~ arr[n-1]。排序开始,每次从无序列表中取出第一个元素,找到相应的位置,并将其按照插入有序列表中。

1.3 插入排序的时间复杂度和空间复杂度等

算法名称

平均时间复杂度

最好情况

最坏情况

空间复杂度

稳定性

插入排序

O(n^2)

O(n)

O(n^2)

O(1)

稳定

2. 代码演示

代码语言:javascript
复制
/**
 * @author shengjk1
 * @date 2020/4/9
 */
public class InsertSort {
	public static void main(String[] args) {
		int[] arr = new int[8];
		for (int i = 0; i < 8; i++) {
			arr[i] = (int) (Math.random() * 80000000);
		}

		for (int i = 1; i < arr.length; i++) {
			int insertIndex = i;
			int insertValue = arr[insertIndex];
			
			//找到相应的位置
			while (insertIndex - 1 >= 0 && arr[insertIndex - 1] > insertValue) {
				arr[insertIndex] = arr[insertIndex - 1];
				insertIndex--;
			}
			//并将其按照插入有序列表中
			arr[insertIndex] = insertValue;
			System.out.printf("第%d次遍历 insertIndex %d arr:%s", i, insertIndex, Arrays.toString(arr));
			System.out.println();
		}
	}
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-04-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 插入排序
    • 1.1 插入排序的基本介绍
      • 1.2 插入排序思想
        • 1.3 插入排序的时间复杂度和空间复杂度等
        • 2. 代码演示
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档