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

想开个网站怎样开公司南京做网站的额

想开个网站怎样开公司,南京做网站的额,小商店助手小程序,网页游戏开发软件文章目录 一:基本概念1.1 介绍1.2 原理1.3 插入排序法思想 二:代码实现2.1 源码2.2 执行结果2.3 测试八万条数据 三:算法分析3.1 时间复杂度3.2 空间复杂度3.3 稳定性 一:基本概念 1.1 介绍 插入式排序属于内部排序法&#xff0…

文章目录

  • 一:基本概念
    • 1.1 介绍
    • 1.2 原理
    • 1.3 插入排序法思想
  • 二:代码实现
    • 2.1 源码
    • 2.2 执行结果
    • 2.3 测试八万条数据
  • 三:算法分析
    • 3.1 时间复杂度
    • 3.2 空间复杂度
    • 3.3 稳定性

一:基本概念

1.1 介绍

插入式排序属于内部排序法,是对于欲排序的元素以插入的方式找寻该元素的适当位置,以达到排序的目的。

1.2 原理

一般也被称为 直接插入排序。对于少量元素的排序,它是一个有效的算法。插入排序是一种最简单的排席方法,它的基本思想是
将一个记录插入到已经排好序的有序表中,从而得到一个新的、记录数增 1 的有序表。在其实现过程使用双层循环,外层循环对除
了第一个元素之外的所有元素,内层循环对当前元素前面有序表进行待插入位置查找,并进行移动。

1.3 插入排序法思想

插入排序(InsertionSorting)的基本思想是:把n个待排序的元素看成为一个有序表和一个无序表,开始时有序表中只包含一个元素,无序表中包含有n-1个元素,排序过程中每次从无序表中取出第一个元素,把它的排序码依次与有序表元素的排序码进行比较,将它插入到有序表中的适当位置,使之成为新的有序表。

  1. 将待排序序列分为两部分,一部分有序一部分无序。
  2. 我们把第一个元素看作有序序列,从第二个元素到最后为无序序列。
  3. 将无序序列中每一个元素依次插入到有序序列的合适位置–从小到大(从大到小)。

在这里插入图片描述

二:代码实现

2.1 源码


/*** 插入排序** @author ikun*/
public class InsertSort {public static void main(String[] args) {int[] array = new int[5];for (int i = 0; i < array.length; i++) {//Math.random() * 80000生成0到100的随机数array[i] = (int) (Math.random() * 80);}System.out.println("排序前:" + Arrays.toString(array));insertSort(array);}/*** 插入排序** @param array 需要排序的数组*/public static void insertSort(int[] array) {for (int i = 1; i < array.length; i++) {//使用逐步推倒的方式来讲解,便于理解//第一轮  {101, 34, 119, 1} -> { 34,101,119,1}//定义待插入的数据//第一轮的话,待插入的数就是array[1]int insertVal = array[i];//定义待插入数据的下标,即array[1]的前一个下标//int insertIndex = 1 - 1;int insertIndex = i - 1;//给insertVal找到一个插入的位置//说明//1.insertIndex >= 0是保证再给insertIndex找插入位置时,不会数组下标越界//2.insertVal < array[insertIndex]说明待插入的数,还没找到插入的位置//3.此时需要将array[insertIndex],也就是101后移while (insertIndex >= 0 && insertVal < array[insertIndex]) {//将array[insertIndex]后移array[insertIndex + 1] = array[insertIndex];//因为要和前面每一个数据进行比较,所以要将要插入的位置减一,挨个比较insertIndex--;}//当退出while循环时,说明插入的位置找到,则insertIndex + 1array[insertIndex + 1] = insertVal;System.out.println("第" + i + "轮插入后:" + Arrays.toString(array));}}}

2.2 执行结果

在这里插入图片描述

2.3 测试八万条数据

在这里插入图片描述

可以看出执行的时间只有370ms,是低于冒泡排序和选择排序的

三:算法分析

3.1 时间复杂度

O(n2)

3.2 空间复杂度

O(1)

3.3 稳定性

稳定的排序算法,其稳定性在于相同值的元素进行插入排序完成后相对位置不发生改变。

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

相关文章:

  • 化妆品电子商务网站建设策划书深圳福田区有哪些大公司
  • 做羞羞的事的视频网站手机网站建设西安
  • 淘宝做首页热点的什么网站建设行官方网站
  • 百度怎么收录网站桂林市临桂区城乡建设局网站
  • 四川建设部官方网站芜湖公司企业排名
  • 外贸企业网站评价案例网站设计怎么用黑色
  • 网站建设代理都有哪些企查查企业信息查询免费
  • 网页制作费用明细北京seo网站
  • 南宁国贸网站建设wordpress 电子书模板
  • 深圳生产型企业网站建设国外企业网站怎么做
  • 学生网站作品建设一个网站主要受哪些因素的影响
  • 李可做的网站迅雷下载宝 做网站
  • 自己做网站大概需要多少钱北京网站网站建设
  • 哪些属于网站评论建设网站的公司要什么资质吗
  • 网站建设管理成本估计易联网站建设
  • 双通网络网站建设重庆做网站优化推广的公司
  • 谢岗镇网站仿做h5打开小程序
  • 网站的竞品分析怎么做网站首页添加代码
  • 龙岗建网站公司小型app开发公司
  • wordpress建站后发布如何登录qq网页版
  • 建站行业前景优惠券怎做网站
  • 山东川畅信息技术有限公司网站建设网站备案导致网站被k
  • 个人开网站招聘网站做招聘顾问
  • 网站后台登录界面做puzzle的网站
  • 五指山住房建设局网站wordpress网站正在维护中
  • 容桂医疗网站建设抖音电商培训
  • 凡科建站好用吗中国建设银行总行网站
  • 南昌网站seo费用建设网站用的软件
  • 嘉兴企业网站服装网站建设的需求
  • 做seo营销网站上海闵行网站制作公司