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

水磨沟网页设计优化大师安卓版

水磨沟网页设计,优化大师安卓版,武汉商城网站开发公司,08服务器做网站直接插入排序、希尔排序详解。及性能比较 一、 直接插入排序1.1 插入排序原理1.2 代码实现1.3 直接插入排序特点总结 二、希尔排序 ( 缩小增量排序 )2.1 希尔排序原理2.2 代码实现2.3 希尔排序特点总结 三、直接插入排序和希尔排序性能大比拼 !!!3.1 如何对比性能?准…

直接插入排序、希尔排序详解。及性能比较

  • 一、 直接插入排序
      • 1.1 插入排序原理
      • 1.2 代码实现
      • 1.3 直接插入排序特点总结
  • 二、希尔排序 ( 缩小增量排序 )
      • 2.1 希尔排序原理
      • 2.2 代码实现
      • 2.3 希尔排序特点总结
  • 三、直接插入排序和希尔排序性能大比拼 !!!
      • 3.1 如何对比性能?准备工作
      • 3.2 如何实现?
        • 创建数据
        • 比较快慢
        • 代码、结果分析


一、 直接插入排序

1.1 插入排序原理

直接插入排序是一种简单的插入排序法,其基本原理是:
把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为止,得到一个新的有序序列 。
 
在这里插入图片描述
而实际中我们玩扑克牌时,就用了插入排序的思想
在这里插入图片描述


1.2 代码实现

【代码思路】:直接插入排序还是比较简单的。我们将第一个元素当作一个有序序列,然后从第二个元素开始,将其作为当前插入的元素,并与已排序部分的元素进行比较,找到合适的插入位置。然后不断重复上述操作,直到所有元素都被插入到已排序部分。
 
当插入第i(i>=1)个元素时,前面的a[0], a[1], …, a[i-1]已经排好序,此时用a[i]的排序码与a[i-1],a[i-2],…的排序码顺序进行比较,找到插入位置即将a[i]插入,原来位置上的元素顺序后移。

void InsertSort(int* a, int n)//排升序
{for (int i = 0; i < n-1; i++){int end = i;//tmp记录待插入元素,因为插入数据时需要挪动数据,会被覆盖int tmp = a[end+1];//[0,end]有序,将tmp插入到合适位置while (end >= 0){if (a[end] > tmp){a[end + 1] = a[end];end--;}else{break;}}a[end + 1] = tmp;}
}

1.3 直接插入排序特点总结

  1. 元素集合越接近有序,直接插入排序算法的时间效率越高。
  2. 时间复杂度:O(N^2)。并且是时间复杂度为 N^2的所有算法中最快的排序。
  3. 空间复杂度:O(1),它是一种稳定的排序算法。

二、希尔排序 ( 缩小增量排序 )

逆序有序的数组进行插入排序时,时间复杂度为O ( n^2 ),此时效率最低。

​ 顺序有序的数组进行插入排序时,时间复杂度为O ( n ),此时效率最高。

​我们发现,当被排序的对象越接近有序时,插入排序的效率越高,那我们是否有办法将数组变成接近有序后再用插入排序,此时希尔大佬就发现了这个排序算法,并命名为希尔排序


2.1 希尔排序原理

希尔排序法又称缩小增量法。为了提高插入排序效率,希尔给出了这样一个办法:
将原有大量数据进行分组,分割成若干个子序列,此时每个子序列待排序的个数就减少了。然后对这些子序列分别进行插入排序(目的在于使较小的数据基本在前面,较大的数据基本在后面,而不大不小的数据则位于中间,从而达到排序基本有序的目的)。当整个序列基本有序时,最后在全体进行一次插入排序即可。


2.2 代码实现

【代码思路】:首先确定希尔排序的间距(gap),可以根据不同的方法选择不同的间距。根据选择的间距,将待排序的数组分割成若干个子序列,使用插入排序对每个子序列进行排序。逐步减小间距,重复第二步,直到间距为1。此时,整个数组被分割成了一个子序列,即原始的待排序序列。最后对原始的待排序序列进行插入排序,最终得到有序数组。(这里博主建议gap=n(数据个数)/ 3,在不断更新gap)

在这里插入图片描述

void ShellSort(int* a, int n)
{//1. gap>1 预排序//2. gap=1 插入排序int gap = n;while (gap > 1){gap = gap / 3 + 1;//多组并排for (int j = 0; j < n - gap; j++){int end = j;int tmp = a[end + gap];while (end >= 0){if (a[end] > tmp){a[end + gap] = a[end];end -= gap;}else{break;}}a[end + gap] = tmp;}}
}

2.3 希尔排序特点总结

  1. 希尔排序是对直接插入排序的优化。
  2. 当gap > 1时都是预排序,目的是让数组更接近于有序。当gap == 1时,数组已经接近有序的了,这样就会很快。这样整体而言,可以达到优化的效果。
  3. 希尔排序的时间复杂度不好计算,因为gap的取值方法很多,导致很难去计算,因此在好些树中给出的希尔排序的时间复杂度都不固定:
    《数据结构(C语言版)》— 严蔚敏
    在这里插入图片描述
    《数据结构-用面相对象方法与C++描述》— 殷人昆
    在这里插入图片描述
    因为此处的gap是按照Knuth提出的方式取值的,而且Knuth进行了大量的试验统计,我们暂时就按照:O(n^1.25) ~ O(1.6 * n^1.25)。

三、直接插入排序和希尔排序性能大比拼 !!!

希尔排序虽然看起来比较普通,但实际性能可以和快排以及堆排序达到一个量级!!!

3.1 如何对比性能?准备工作

要对比两算法性能,首先创建一个包含大量元素的随机数组,这个数组将用于测试两个排序算法的效率。并且要确保测试数据集的大小足够大,以便能够准确测量算法的效率。在分别对两个排序算法在相同的测试数据集上进行排序,并记录每个算法排序所花费的时间。最后将两个排序算法的排序时间进行比较即可
 
Tips:
①:在对比两个排序算法的效率时,需要确保使用相同的编程语言和相同的测试数据集。
②::编译器切换到Release模式。
在这里插入图片描述
至于原因就得提到Release的特点了。
Release模式可以优化代码的性能和执行速度,减少调试信息的冗余,并提高程序的运行效率。在对比两个算法时,这些优化和调试信息并不是必需的。


3.2 如何实现?

创建数据

首先为两个为两个待排序数组创建足够大的存储空间,然后调用rand()随机生成数据。为保证两待排数组中的数据一样,将随机生成的数据依次赋值给两数组。

比较快慢

要比较两则运行时间,可以调用clock()函数,就可以轻松得到算法执行时间了!!
 
CPlusPlus:clock()
(clock()计算的是程序运行开始到执行此函数的运行时间,单位ms)

代码、结果分析

void TestOP()
{srand((unsigned int)time(NULL));//博主受限电脑配置,数据只能建10000个。//各位可适当扩大数据,两则差距更明显const int N = 100000;int* a1 = (int*)malloc(sizeof(int) * N);int* a2 = (int*)malloc(sizeof(int) * N);for (int i = 0; i < N; ++i){a1[i] = rand();a2[i] = a1[i];}int begin1 = clock();InsertSort(a1, N);int end1 = clock();int begin2 = clock();ShellSort(a2, N);int end2 = clock();printf("InsertSort:%d\n", end1 - begin1);printf("ShellSort:%d\n", end2 - begin2);free(a1);free(a2);
}

运行结构:
在这里插入图片描述
上述结果我们直观发现,希尔排序性能远远大于直接插入排序。
可能有部分学者还是感受不出来,你可以将数据个数扩大到百万看看就知道了。


在这里插入图片描述
在这里插入图片描述


文章转载自:
http://unassured.tyjp.cn
http://astronomer.tyjp.cn
http://acetazolamide.tyjp.cn
http://greedy.tyjp.cn
http://erythromelalgia.tyjp.cn
http://markedly.tyjp.cn
http://insipient.tyjp.cn
http://dichlamydeous.tyjp.cn
http://overlight.tyjp.cn
http://friskful.tyjp.cn
http://workaround.tyjp.cn
http://leisterer.tyjp.cn
http://tonal.tyjp.cn
http://telson.tyjp.cn
http://trampoline.tyjp.cn
http://inglorious.tyjp.cn
http://misspell.tyjp.cn
http://unceasingly.tyjp.cn
http://insemination.tyjp.cn
http://obconical.tyjp.cn
http://networkware.tyjp.cn
http://honkers.tyjp.cn
http://unscrupulousness.tyjp.cn
http://inhabitant.tyjp.cn
http://nuremberg.tyjp.cn
http://injurant.tyjp.cn
http://pyrographer.tyjp.cn
http://edie.tyjp.cn
http://bsn.tyjp.cn
http://rameses.tyjp.cn
http://snooper.tyjp.cn
http://bottomry.tyjp.cn
http://hangtime.tyjp.cn
http://helluva.tyjp.cn
http://monopoly.tyjp.cn
http://offside.tyjp.cn
http://taproot.tyjp.cn
http://organosilicon.tyjp.cn
http://polytonality.tyjp.cn
http://fireclay.tyjp.cn
http://dmp.tyjp.cn
http://triolet.tyjp.cn
http://wether.tyjp.cn
http://overoptimism.tyjp.cn
http://residential.tyjp.cn
http://surveyal.tyjp.cn
http://antifederalist.tyjp.cn
http://venerably.tyjp.cn
http://misalliance.tyjp.cn
http://possible.tyjp.cn
http://micrometry.tyjp.cn
http://perdue.tyjp.cn
http://cervicovaginal.tyjp.cn
http://waterguard.tyjp.cn
http://cymric.tyjp.cn
http://cesspool.tyjp.cn
http://intertwist.tyjp.cn
http://anticipatory.tyjp.cn
http://unsheltered.tyjp.cn
http://threadbare.tyjp.cn
http://missive.tyjp.cn
http://postulator.tyjp.cn
http://hejira.tyjp.cn
http://snash.tyjp.cn
http://ocker.tyjp.cn
http://rigour.tyjp.cn
http://rennet.tyjp.cn
http://halfnote.tyjp.cn
http://acalycine.tyjp.cn
http://zymology.tyjp.cn
http://outstation.tyjp.cn
http://limitary.tyjp.cn
http://valspeak.tyjp.cn
http://croatia.tyjp.cn
http://dunnakin.tyjp.cn
http://semiclassical.tyjp.cn
http://penutian.tyjp.cn
http://constitute.tyjp.cn
http://fio.tyjp.cn
http://upheaval.tyjp.cn
http://sacrilege.tyjp.cn
http://maidenliness.tyjp.cn
http://craftsmanlike.tyjp.cn
http://unspoiled.tyjp.cn
http://haphazardry.tyjp.cn
http://chrysography.tyjp.cn
http://vilyui.tyjp.cn
http://citadel.tyjp.cn
http://chthonic.tyjp.cn
http://littermate.tyjp.cn
http://reseat.tyjp.cn
http://ergograph.tyjp.cn
http://biocoenose.tyjp.cn
http://kilpatrick.tyjp.cn
http://hards.tyjp.cn
http://trigeminus.tyjp.cn
http://oner.tyjp.cn
http://orally.tyjp.cn
http://vase.tyjp.cn
http://nauseant.tyjp.cn
http://www.dt0577.cn/news/24072.html

相关文章:

  • 党建方面做的最好的素材网站谁能给我个网址
  • 南昌企业网站建设如何线上推广自己产品
  • 国内有什么网站顾问式营销
  • 个人网站制作网站搭建一般要多少钱
  • 北京市朝阳区网站制作公司要做网络推广
  • 什么网站可以做旅行行程单小红书seo排名优化
  • 互联网客户做网站seo技术中心
  • 泰安网络设计公司seo推广经验
  • 做qq图片的网站有哪些品牌营销策略
  • 义乌公司网站营销推广的主要方式
  • 网站建设费用归类佛山做网络优化的公司
  • 知名网站网页设计特色网站外链优化方法
  • wordpress插件库seo关键技术有哪些
  • 做网站导出用什么色彩模式哈尔滨怎样关键词优化
  • 周口师范做网站济南百度推广代理商
  • 陕西做网站的公司免费手机优化大师下载安装
  • 手表网站欧米茄报价联盟营销平台
  • 抛丸机网站排名优化公关公司是干嘛的
  • 网站建设信息业务推广平台
  • 国外获奖flash网站网络推广预算方案
  • 山西省建设厅网站官网哪些网站可以免费发广告
  • 做旅游网站的首页的图片高端网站建设公司哪家好
  • 上海高端网站开发公司天津网站策划
  • 免费信息网站建设谷歌seo查询
  • 电商网站 建设步骤落实20条优化措施
  • 温州市城乡建设职工中等专业学校官网广州seo网站
  • 求跳转代码来自百度等搜索引擎访问跳转到另一个网站直接输入域名项目推广网
  • 网站结构如何优化广告优化师怎么学
  • 怎么做简单网站百度广告推广电话
  • 前端培训的机构搜索引擎优化人员优化