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

购物网站建设渠道wordpress 如何回到初始化

购物网站建设渠道,wordpress 如何回到初始化,wordpress 知识共享,优必选网站原创不易,转载请注明出处。欢迎点赞收藏~ 归并排序是一种常见的排序算法,它采用了分治的思想。它将一个待排序的数组递归地分成两个子数组,分别对两个子数组进行排序,然后将排好序的子数组合并成一个有序数组。 具体的归并排序过…

原创不易,转载请注明出处。欢迎点赞收藏~

归并排序是一种常见的排序算法,它采用了分治的思想。它将一个待排序的数组递归地分成两个子数组,分别对两个子数组进行排序,然后将排好序的子数组合并成一个有序数组。

具体的归并排序过程如下:

  1. 将待排序的数组不断地二分,直到每个子数组只剩下一个元素。
  2. 对每个子数组进行合并操作,即将两个有序的子数组合并成一个有序数组。合并操作是通过比较两个子数组的首元素,选取较小的元素放入临时数组中,然后移动相应的指针,重复此过程直到其中一个子数组为空,再将另一个子数组中的剩余部分直接放入临时数组中。
  3. 重复步骤2,直到所有的子数组都被合并成一个有序数组。

归并排序的时间复杂度为 O(nlogn),其中 n 表示待排序数组的长度。这是因为在每一层递归中,需要将所有的子数组都进行合并,而合并两个长度为 n 的有序数组的时间复杂度为 O(n)。总共需要进行 logn 层的递归,因此时间复杂度为 O(nlogn)。

归并排序的空间复杂度为 O(n),主要是由于合并过程中需要使用一个临时数组来存储排序结果。

归并排序是一种稳定的排序算法,适用于各种规模的数据集。但由于它需要额外的空间来存储临时数组,所以在处理大规模数据时,可能会占用较多的内存。

以下是一个基于C语言的归并排序示例:

#include <stdio.h>// 合并两个有序数组
void merge(int arr[], int left[], int leftSize, int right[], int rightSize)
{int i = 0, j = 0, k = 0;// 比较两个子数组的元素,将较小的元素放入原始数组arr中while (i < leftSize && j < rightSize){if (left[i] <= right[j]){arr[k++] = left[i++];}else{arr[k++] = right[j++];}}// 将剩余部分的元素放入arr中while (i < leftSize){arr[k++] = left[i++];}while (j < rightSize){arr[k++] = right[j++];}
}// 归并排序
void merge_sort(int arr[], int size)
{// 递归终止条件:当数组只有一个元素时,无需继续划分if (size <= 1){return;}int mid = size / 2;int left[mid];int right[size - mid];// 将数组划分为两个子数组for (int i = 0; i < mid; i++){left[i] = arr[i];}for (int i = mid; i < size; i++){right[i - mid] = arr[i];}// 对两个子数组分别进行归并排序merge_sort(left, mid);merge_sort(right, size - mid);// 合并两个有序子数组merge(arr, left, mid, right, size - mid);
}int main()
{int arr[] = {7, 2, 4, 1, 5, 3};int size = sizeof(arr) / sizeof(arr[0]);printf("排序前的数组:\n");for (int i = 0; i < size; i++){printf("%d ", arr[i]);}merge_sort(arr, size);printf("\n排序后的数组:\n");for (int i = 0; i < size; i++){printf("%d ", arr[i]);}putchar('\n');return 0;
}

这段代码实现了归并排序算法。归并排序是一种基于分治思想的排序算法,它将待排序的数组分成两个子数组,分别进行排序,然后合并两个有序的子数组,从而得到完整的有序数组。

代码中的merge()函数用于合并两个有序数组。它通过比较两个子数组的元素,将较小的元素依次放入原始数组arr中。最后,将剩余部分的元素放入原始数组中,以确保所有元素都被归并到正确的位置。

merge_sort()函数是归并排序的核心部分。它首先递归地将数组划分为两个子数组,然后对这两个子数组分别调用merge_sort()函数进行排序。最后,调用merge()函数将两个有序的子数组合并为一个有序数组。

在main()函数中,我们声明了一个整型数组arr并初始化了一些元素。然后,我们调用merge_sort()函数对数组进行归并排序,并打印原始数组和排序后的数组。

最终输出的结果是原始数组和排序后的数组。你可以根据需要修改输入的数组和数组长度,来验证归并排序的效果。

运行如上代码,你可以看到以下输出:

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

相关文章:

  • 做网站有名的公司有哪些多多进宝cms网站建设
  • 怎么在网站做谷歌广告域名经纪公司推荐
  • 网站免费建站 网页不需要备案网络推广平台代理
  • 怎样学做网络推广seo网络营销案例分析
  • 手套网站模板手机在线做ppt模板下载网站有哪些
  • 深圳场站建设发展有限公司电商平台搭建八个步骤
  • 做网站的公司哪家有名舟山做网站
  • 小白网站搭建教程服务器建站教程
  • 南昌城市旅游网站建设二级建造师考试
  • 中小型网站有哪些西安网站 技术支持牛商网
  • 如何制作企业网站的版式他达拉非功效与作用主要会有哪些
  • 企业网站建设方案平台用jsp和mysql做网站
  • 淮安营销型网站建设网线制作图解
  • flash网站读条怎么做拼多多关键词排名查询工具
  • 中国工程建设工程造价管理协会网站想做个网站都需要什么
  • 除了做视频网站还能做什么网站餐饮店如何引流与推广
  • 衡水电商网站建设使用他人api做网站
  • 苏州住房和城乡建设厅网站太原做淘宝网站的
  • 如何向百度提交自己的网站校园网站建设实施方案
  • 商洛 网站建设跨境电商最火的产品
  • 企业平台网站建设方案加快政务网站群建设管理
  • 如何开发微信微网站页面紧急更新自动转跳直播
  • 深深圳市建设局网站网页设计个人实训报告
  • 物流那个网站做推广好wordpress企业主题下载地址
  • 装修公司网站dede模板做漫画网站的需求
  • 有专业做网站的吗网站公司网站建设流程王晴儿
  • 万江网站建设公司python 手机网站开发
  • 做百度手机网站关键词uniapp页面设计
  • 网站空间租用哪家好软件开发具体做什么
  • 如何做好网站建设前期网站规划一个完整网页的制作