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

wordpress 图片网站推销产品的软文500字

wordpress 图片网站,推销产品的软文500字,鳌江网站建设,低价高端网站设计归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。 首先考虑下如何将将二个有序数列合并。这个非常简单,只要从比较二个数列的第一个数,谁小就先取谁,取…

归并排序是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(Divide and Conquer)的一个非常典型的应用。

首先考虑下如何将将二个有序数列合并。这个非常简单,只要从比较二个数列的第一个数,谁小就先取谁,取了后就在对应数列中删除这个数。然后再进行比较,如果有数列为空,那直接将另一个数列的数据依次取出即可。

 

View Code
 1 //将有序数组a[]和b[]合并到c[]中
 2 void MemeryArray(int a[], int n, int b[], int m, int c[])
 3 {
 4     int i, j, k;
 5 
 6     i = j = k = 0;
 7     while (i < n && j < m)
 8     {
 9         if (a[i] < b[j])
10             c[k++] = a[i++];
11         else
12             c[k++] = b[j++]; 
13     }
14 
15     while (i < n)
16         c[k++] = a[i++];
17 
18     while (j < m)
19         c[k++] = b[j++];
20 }

 

可以看出合并有序数列的效率是比较高的,可以达到O(n)。

解决了上面的合并有序数列问题,再来看归并排序,其的基本思路就是将数组分成二组A,B,如果这二组组内的数据都是有序的,那么就可以很方便的将这二组数据进行排序。如何让这二组组内数据有序了?

可以将A,B组各自再分成二组。依次类推,当分出来的小组只有一个数据时,可以认为这个小组组内已经达到了有序,然后再合并相邻的二个小组就可以了。这样通过先递的分解数列,再合数列就完成了归并排序。

 

View Code
 1 //将有二个有序数列a[first...mid]和a[mid...last]合并。
 2 void mergearray(int a[], int first, int mid, int last, int temp[])
 3 {
 4     int i = first, j = mid + 1;
 5     int m = mid,   n = last;
 6     int k = 0;
 7     
 8     while (i <= m && j <= n)
 9     {
10         if (a[i] <= a[j])
11             temp[k++] = a[i++];
12         else
13             temp[k++] = a[j++];
14     }
15     
16     while (i <= m)
17         temp[k++] = a[i++];
18     
19     while (j <= n)
20         temp[k++] = a[j++];
21     
22     for (i = 0; i < k; i++)
23         a[first + i] = temp[i];
24 }
25 void mergesort(int a[], int first, int last, int temp[])
26 {
27     if (first < last)
28     {
29         int mid = (first + last) / 2;
30         mergesort(a, first, mid, temp);    //左边有序
31         mergesort(a, mid + 1, last, temp); //右边有序
32         mergearray(a, first, mid, last, temp); //再将二个有序数列合并
33     }
34 }
35 
36 bool MergeSort(int a[], int n)
37 {
38     int *p = new int[n];
39     if (p == NULL)
40         return false;
41     mergesort(a, 0, n - 1, p);
42     delete[] p;
43     return true;
44 }

 

归并排序的效率是比较高的,设数列长为N,将数列分开成小数列一共要logN步,每步都是一个合并有序数列的过程,时间复杂度可以记为O(N),故一共为O(N*logN)。因为归并排序每次都是在相邻的数据中进行操作,所以归并排序在O(N*logN)的几种排序方法(快速排序,归并排序,希尔排序,堆排序)也是效率比较高的

 

 

转载于:https://www.cnblogs.com/xiaojiaohuazi/archive/2013/03/22/2974819.html

http://www.lbrq.cn/news/2396413.html

相关文章:

  • 用模板做网站的方法免费seo培训
  • 做名片制作网站有什么软文发布软件
  • 网站建设修改营销网站建设哪家好
  • 朝阳专业网站建设公司产品销售方案与营销策略
  • 网站建设与规划实验心得百度seo关键词优化电话
  • 深圳建设网站公司全球访问量top100网站
  • 针对人群不同 网站做细分关键词三年级
  • 物联网开发平台新河seo怎么做整站排名
  • 北京政府网站开发外贸网站
  • 古董专家官方网站微信新冠疫情最新消息今天公布
  • 浙江省建设委员会网站aso排名优化知识
  • 朔州市2018年建设工程网站如何在百度上营销
  • 网站解析出问题 邮件收不到了网络营销策划师
  • 武安建设局网站十大引擎网址
  • wordpress https错误推广学院seo教程
  • 找人做博彩网站互动营销平台
  • 哪个网站可以做任务nba最新消息
  • 做风帆网站需要多少钱如何搭建网站平台
  • 网站设计公司网站设计公司今天今日头条新闻
  • 广东贸易网站开发百度seo建议
  • 门户网网站seo怎么做品牌营销的四大策略
  • 合肥网站建设怎么做湖南seo优化报价
  • 网站禁用复制流量神器
  • 无锡 网站 seo 优化网站建设公司业务
  • 商贸网站建设广州网络营销推广
  • 网站内部优化软文推广案例大全
  • 电子商城网站开发武汉seo服务外包
  • 贵州省网站集约化建设网络营销收获与体会
  • 长治网站制作公司手机制作网页用什么软件
  • 淘宝做导航网站有哪些功能站长百度
  • Entity Component System架构
  • Machine Learning HW2 report:语音辨识(Hongyi Lee)
  • 去中心化交易所(DEX)深度解析:解码行业头部项目
  • 从“代码工坊“到“思维引擎“:Claude Code如何重塑编程权力结构
  • MBIST - Memory BIST会对memory进行清零吗?
  • 闲庭信步使用图像验证平台加速FPGA的开发:第二十课——图像还原的FPGA实现