当前位置: 首页 > news >正文

衡阳网站建设 千度网络复古传奇网页版游戏

衡阳网站建设 千度网络,复古传奇网页版游戏,广德做网站设计开发,网页制作个人介绍模板目录 1. 图示解析 2. 原理解析 3. 代码实现 4. 性能分析 5. 折半插入排序(拓展) 直接插入排序和选择排序的第一趟就是第一个关键字 ! 1. 图示解析 2. 原理解析 整个区间被分为:① 有序区间;② 无序区间 每次选…

目录

1. 图示解析

2. 原理解析

3. 代码实现

4. 性能分析

5. 折半插入排序(拓展)


直接插入排序和选择排序的第一趟就是第一个关键字 !

1. 图示解析

2. 原理解析

整个区间被分为:① 有序区间;② 无序区间

每次选择无序区间的第一个元素,在有序区间内选择合适的位置插入。

为了各位小伙伴能更加清楚地认识直接插入排序,我接下用文字描述直接插入排序的过程!

想通过一个例子来体会一下插入排序的执行流程。例如,对原始序列{49,38,65,97,76,13,27,49}进行直接插入排序的具体流程如下(序列中有两个49,其中一个加下划线,加以区分)。

原始序列:49   38   65   97   76   13   27   49

(1)一开始只看49,一个数当然是有序的。

有序序列:{49};无序序列:{38   65   97   76   13   27   49}

(2)向有序序列插入38,38 < 49,所以49向后移动一个位置,38插入到49原来的位置,这趟排序后的结果为:

有序序列:{38   49};无序序列:{ 65   97   76   13   27   49}

(3)向有序序列插入65,65  > 49,所以不需要移动,65就应该在49只有,这趟排序后的结果为:

有序序列:{38   49   65};无序序列:{97   76   13   27   49}

(4)插入97,97 > 65,所以不需要移动,97就应该在65之后,这趟排序后的结果为:

有序序列:{38   49   65   97};无序序列:{76   13   27   49}

(5)插入76,76 < 97,所以97向后移动一个位置,继续比较,76 > 65,65不需要移动,76应该插入在65之后,97之前,这趟排序后的结果为:

有序序列:{38   49   65   76   97};无序序列:{13   27   49}

(6)插入13,13 < 97,97后移;13 < 76,76后移;这样逐个向前比较,发现13应该插入在最前面,这趟排序后的结果为:

有序序列:{13   38   49   65   76   97};无序序列:{27   49}

(7)插入27,还是从后面前行比较,确定27应该插入在13之后、38之前,这趟排序后的结果为:

有序序列:{13   27   38   49   65   76   97};无序序列:{49}

(8)最后插入49,同样从后向前逐个比较,知道49 = 49 < 65,它的位置确定,直接插入排序全过程完成。最后的排序结果为:

有序序列:{13   27   38   49   49   65   76   97};无序序列:{}

总结算法思想:

每趟将一个待排序的关键字按照其值的大小插入到已经拍好的部分有序序列的位置上直到所有待排序关键字都插入到有序序列中为止。

注意!!!!!!!!!!

小伙伴们请注意,我这里省略了i = 0的情况,从i = 1开始,也就是一开始只看49,一个数当然是有序的。如果是在考试中一定要把i = 0的情况作为第一趟(针对专升本和考研都一样)。

3. 代码实现

    //直接插入排序public static void insertSort(int[] arr) {//代码可以从i = 1开始算起,但是做题画图时,一定要从i = 0开始算起for (int i = 1; i < arr.length; i++) {int j = i - 1;int tmp = arr[i];for (; j >= 0; j--) {//如果arr[j] > tmp变成arr[j] >= tmp就变成不稳定了if (arr[j] > tmp) {arr[j + 1] = arr[j];} else {break;}}arr[j + 1] = tmp;}}public static void main(String[] args) {int[] arr = {10,9,8,7,6,5,4,3,2,1};Sort.insertSort(arr);for (int x : arr) {System.out.print(x + " ");}}

4. 性能分析

时间复杂度空间复杂度
最好平均最坏
O(N)O(N^2)O(N^2)O(1)
数据有序数据逆序

稳定性:稳定

如果一个排序是稳定的,那么就可以实现为不稳定的

但是如果一个算法本身是不稳定的,你没办法实现为稳定的排序

插入排序,原始数据越有序,时间效率越高!

检测一下:

    //创建升序数组public static void createArray1(int[] arr){for(int i = 1;i<10000;i++){arr[i - 1] = i;}}//创建逆序数组public static void createArray2(int[] arr){for(int i = 0;i<10000;i++){arr[i] = 10000 - i;}}public static void main(String[] args) {int[] arr1 = new int[10000];Test.createArray1(arr1);long s1 = System.currentTimeMillis();Sort.insertSort(arr1);long e1 = System.currentTimeMillis();System.out.println("数组有序的情况:"+(e1 - s1));int[] arr2 = new int[10000];Test.createArray2(arr2);long s2 = System.currentTimeMillis();Sort.insertSort(arr2);long e2 = System.currentTimeMillis();System.out.println("数组逆序的情况:"+(e2 - s2));}

 

5. 折半插入排序(拓展)

在有序区间选择数据应该插入的位置时,因为区间的有序性,可以利用折半查找的思想来增加插入算法的效率!

    //折半插入排序public static void bsInsertSort(int[] arr) {//代码可以从i = 1开始算起,但是做题画图时,一定要从i = 0开始算起for (int i = 1; i < arr.length; i++) {int v = arr[i];int left = 0;//左边标记永远从0下标开始int right = i;while(left < right){int mid = (left + right) / 2;//需要[left right)if(arr[mid] < v){//如果区间要闭,就赋值mid + 1或者mid - 1left = mid + 1;}else{//如果右区间要开,就赋值midright = mid;}}for (int j = i; j > left; j--) {arr[j] = arr[j - 1];}arr[left] = v;}}

http://www.yayakq.cn/news/377934/

相关文章:

  • 有没有专门做教程的网站如何建设自己的企业网站
  • 泰安网站建设哪家好网络维护协议
  • 做外贸自己公司的网站一定要吗网站怎么建设好看
  • 中国风网站表现软件开发app制作
  • 自己做的网站怎样对接支付宝贵城乡建设官方网站
  • C语言做网站需要创建窗口吗爱采购
  • 运动服饰网站建设预算公众号软文范例100
  • 淘宝的网站怎么做的好百度推广培训机构
  • 站内推广方式有哪些ai做网站 如何切图
  • 网站建设经费预算沈阳前端好找工作吗
  • 宁波模板建站多少钱旅游网络网站建设方案
  • 企业网站都有哪些石家庄建设厅官方网站
  • 做网站怎么做多少钱网站建设项目验收意见
  • 整站优化seo排名点击zencart 网站安装
  • 资源网站平台建设方案wordpress 客户端源码
  • 宝丰网站制作公司遂宁网站建设
  • 成都集团网站设计推荐网页与制作
  • 苏州市网站建设服务网站建设的常用词
  • apache网站开启gzip财经网站模板
  • 网站内网页标题对百度排名郑州好的建网站公司
  • 腾讯云网站备案做视频网站视频存放在哪里
  • 选择常州网站建设公司一个软件的制作过程
  • 用什么做网站更快捷方便常见的cms网站
  • 住房和城乡建设部网站招聘国内网络营销公司排名
  • 中山快速做网站费用网站建设咨询话术技巧
  • 网站备案 多ip个人养老保险网上怎么缴费
  • 四川省建设厅网站投诉解读wordpress php代码
  • 学做窗帘的网站怎么做游戏网站编辑
  • 国家高新技术企业认定官网台州商品关键词优化
  • 网站建设与软件开发哪个好赚钱wordpress打赏分享