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

个体户可以备案网站吗/百度 seo优化作用

个体户可以备案网站吗,百度 seo优化作用,网页设计代码网站,广州网站建设定制多少钱一、插入排序 1.算法思想 插入排序(Insertion Sort)是一种简单的排序算法,其基本思想是:将待排序的元素插入到已经有序的序列中,从而逐步构建有序序列。 具体过程如下: 把待排序的数组分为已排序和未排…

一、插入排序

1.算法思想

插入排序(Insertion Sort)是一种简单的排序算法,其基本思想是:将待排序的元素插入到已经有序的序列中,从而逐步构建有序序列。

具体过程如下:

  1. 把待排序的数组分为已排序和未排序两部分。初始时,已排序部分只有第一个元素,即数组的第一个元素被认为是已经有序的
  2. 从第二个元素开始,也就是未排序部分的第一个元素,将其与已排序部分的元素从后往前依次比较(因为从后往前越来越有序,则越快)
  3. 如果当前元素(未排序部分的元素)小于已排序部分的某个元素,就将该元素往后移动一位,为当前元素腾出位置
  4. 重复步骤 3,直到找到一个已排序元素小于或等于当前元素,或者已经比较到了已排序部分的第一个元素。
  5. 将当前元素插入到合适的位置,这样就将一个未排序元素插入到了已排序序列中,使得已排序序列的长度增加 1。
  6. 对未排序部分的下一个元素重复步骤 2 到 5,直到所有元素都被插入到已排序序列中,此时整个数组就完成了排序。

插入排序就像人们平时整理扑克牌一样,每次从手中的未整理牌中拿起一张,然后将其插入到已整理好的牌中的合适位置。

2.代码实现

//插入排序
void InsertSort(int* arr, int len)
{int tmp,i,j;for (i = 1; i < len; i++)//i是当前要处理的数字的下标{tmp = arr[i];//取出当前要插入的元素//遍历已排序的部分for (j = i - 1; j >= 0; j--)//从i的前一个开始找位置,从后往前找,找比当前数字小的,同时移动数据{if (arr[j] > tmp){arr[j + 1] = arr[j];//将比tmp大的元素后移}else{//arr[j + 1] = tmp;break;}}arr[j + 1] = tmp;//将tmp插入正确位置,放到比tmp小的元素的后面}
}

3.复杂度分析 

该算法在最好情况下(数组已经有序)时间复杂度为O(n),越有序越快,完全有序为O(n);在最坏情况下(数组逆序)时间复杂度为O(n2),空间复杂度为O(1),是一种稳定的排序算法。

所以在一组数据基本有序的情况下,用直接插入排序。

二、希尔排序

1.算法思想

希尔排序(Shell Sort)是插入排序的一种改进版本,也称为缩小增量排序。

希尔排序的基本思想是将原始数据分成若干个子序列,每个子序列的元素间隔较大,然后对每个子序列进行插入排序。随着排序的进行,逐渐减小子序列的元素间隔,直到间隔为 1,此时整个序列基本有序,再进行一次普通的插入排序即可完成排序

注意:分组时采用间隔式的排序!

希尔排序采用间隔式排序主要有以下原因:
加快元素移动速度:希尔排序将原始数据分成多个子序列,每个子序列的元素间隔较大。这样在排序过程中,元素可以以较大的步长移动,能更快地将元素移动到其最终位置附近。例如,对于一个很大的数组,如果直接进行插入排序,每个元素可能需要移动很多次才能到达最终位置。但希尔排序通过大间隔分组,让元素先进行 “远距离” 的移动,初步将数据大致排序,减少了后续插入排序时元素的移动次数。
改善最坏时间复杂度:传统的插入排序在最坏情况下(如数组完全逆序)时间复杂度为O(n2)
希尔排序通过间隔式排序,使数组在初始阶段就接近有序状态,当间隔逐渐减小时,数组已经基本有序,此时再进行插入排序,就可以避免最坏情况的发生,其平均时间复杂度介于O(n)
到O(n2)之间,通常能达到O(n1.3)左右,性能相比直接插入排序有显著提升。
利用局部有序性:在间隔式排序过程中,每个子序列内部进行排序,使得子序列逐渐变得有序。随着间隔逐渐缩小,子序列的长度逐渐增加,而之前已经排好序的子序列能为后续更大规模的排序提供一定的有序基础,充分利用了数据的局部有序性,提高排序效率。

希尔排序核心思想就是:1 分组;2 直接插入排序:越有序越快

2.代码实现

//希尔排序
//一趟希尔排序 gap为组数(间隔)
static void Shell(int* arr, int len, int gap)
{int tmp, i, j;for (i = gap; i < len; i++)//i是当前要处理的数字的下标{tmp = arr[i];//取出当前要插入的元素//遍历已排序的部分for (j = i - gap; j >= 0; j-=gap)//从i的前一个开始找位置,从后往前找,找比当前数字小的,同时移动数据{if (arr[j] > tmp){arr[j + gap] = arr[j];//将比tmp大的元素后移gap}else{break;}}arr[j + gap] = tmp;//将tmp插入正确位置}
}
void ShellSort(int* arr, int len)
{int drr[] = { 5,3,1 };//分组数,最后一个组数一定为1for (int i = 0; i < sizeof(drr) / sizeof(drr[0]); i++)//循环控制分组的次数,此处分3次(5,3,1){Shell(arr, len, drr[i]);//一趟希尔排序}
}

3.复杂度分析

希尔排序不稳定。

时间复杂度:希尔排序的时间复杂度与增量序列的选择有关。在最坏情况下,希尔排序的时间复杂度为O(n2)。在最好情况下,希尔排序的时间复杂度为O(nlogn)。
空间复杂度:希尔排序是一种原地排序算法,只需要常数级别的额外空间,因此空间复杂度为
O(1)。
稳定性:希尔排序是不稳定的排序算法。在排序过程中,相同元素的相对位置可能会发生改变。
希尔排序通过将原始数据分成多个子序列,每个子序列的元素间隔较大,使得元素可以更快地移动到其最终位置,从而提高了排序效率。它在处理大规模数据时表现较好,是一种常用的排序算法。

以上是排序算法第二部分关于插入排序的知识,如果有帮助可以点赞收藏一下,会持续更新输出有用的内容,感兴趣可以关注我!

http://www.lryc.cn/news/577586.html

相关文章:

  • 站长要维护网站/seo网络推广有哪些
  • 河南网站优化要多少钱/营销方式有哪几种
  • 黄石做网站要多少钱/windows优化大师可以卸载吗
  • 网站图标可以用ps 做吗/百度问问首页
  • 成都市城乡建设委员会官方网站/360广告推广平台
  • 东莞知名网站建设/网站推广的6个方法是什么
  • reactjs 做的网站/短视频seo代理
  • 网站维护托管公司/营销软文300字
  • 中宁网站建设公司/营销型网站建设套餐
  • 手表 网站策划/网络营销的方法是什么
  • 旅游网站建设的概念/下载谷歌浏览器并安装
  • 电脑系统做的好的网站好/百度云搜索引擎入口
  • 如何做网站的seo/石家庄seo外包的公司
  • 珠宝类网站建设可执行报告/搜索引擎优化的主题
  • 网站划分栏目/郑州手机网站建设
  • 资源网站模板/百度账号客服
  • 云南建设监理协会网站/谷歌浏览器安卓版
  • 网站建设大赛策划书/海阳seo排名优化培训
  • 帮人做钓鱼网站/如何在各大网站发布信息
  • 网站更换服务器 备案/泉州seo按天收费
  • 北京海淀区是几环/重庆seo网站推广费用
  • 河北网站建设团队/电商网站建设
  • 百度上做网站/官方百度app下载安装
  • 注册域名的官方网站/软文推广一般发布在哪些平台
  • 24小时学会网站建设pdf/关键词吉他谱
  • 做外贸需要网站/西安网站建设排名
  • 合肥建站公司有哪家招聘的/百度seo代理
  • 贵州网站建设价格/怎么做盲盒
  • 网站前端培训/网站建设报价明细表
  • 杭州做网站博客/厦门搜索引擎优化