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

商品网站怎么做网上推广怎么弄?

商品网站怎么做,网上推广怎么弄?,生产企业做网站有用吗,深圳设计师工资一般多少P. S.:以下代码均在VS2019环境下测试,不代表所有编译器均可通过。 P. S.:测试代码均未展示头文件stdio.h的声明,使用时请自行添加。 博主主页:LiUEEEEE                        …
P. S.:以下代码均在VS2019环境下测试,不代表所有编译器均可通过。
P. S.:测试代码均未展示头文件stdio.h的声明,使用时请自行添加。

  

在这里插入图片描述

                                           博主主页:LiUEEEEE
                                              C语言专栏
                                            数据结构专栏
                                         力扣牛客经典题目专栏

目录

  • 1、归并排序的基本思想
  • 2、归并排序的实现
    • 2.1. 归并排序的递归实现
    • 2.2. 归并排序的非递归实现
  • 3、归并排序非递归方法实现的常见问题
  • 4、结语

1、归并排序的基本思想


  归并排序的基本思想:
  • 归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法是采用分治法(Divide andConquer)的一个非常典型的应用。将已有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。 归并排序核心步骤:
    在这里插入图片描述



2、归并排序的实现


  归并排序的实现拥有两种方法:
  • 递归实现
  • 非递归实现

  但归根到底其主要思想不会发生变化,以下是归并排序的动态展示图:
在这里插入图片描述

2.1. 归并排序的递归实现


  如上文所展示的效果图可知:
  • 对于归并排序,需使用二叉树中后序的思想,将所给目标数组全部类二分,而后进行递归,当所递归数组个数为1时开始归并。
  • 将归并后的子数组复制到原数组中对应位置,并开启新一轮的归并,这就需要我们动态开辟一个第三方数组tmp来进行辅助。

  
  • 归并排序的递归实现代码如下所示:
void MergeSort(int* a, int* tmp, int begin, int end)
{if (begin >= end)return;int mid = (begin + end) / 2;MergeSort(a, tmp, begin, mid);MergeSort(a, tmp, mid + 1, end);int begin1 = begin, end1 = mid;int begin2 = mid + 1, end2 = end;int i = begin;while (begin1 <= end1 && begin2 <= end2){if (a[begin1] < a[begin2]){tmp[i++] = a[begin1++];}else{tmp[i++] = a[begin2++];}}while (begin1 <= end1){tmp[i++] = a[begin1++];}while (begin2 <= end2){tmp[i++] = a[begin2++];}memcpy(a + begin, tmp + begin, (end - begin + 1) * sizeof(int));
}

2.2. 归并排序的非递归实现


  其思想与递归并无差别,区别在于操作方式:
  • 在递归实现中,我们使用类二分的方法将原目标数组分为2份依次进行二分的归并递归,而在非递归中,我们不再使用类二分的方法,而是直接在原数组上进行操作。
  • 在逻辑上认为原数组已经进行处于递归的过程,即:令gap = 1
  • 第一次对每一个元素进行归并,归并完成后,令 gap *= 2。
  • 第二次对每两个元素进行归并,归并完成后,令 gap *= 2。
  • 第n 次对每2^(n-1)个元素进行归并,归并完成后,令 gap *= 2。
  • 直到gap大于元素原本数组个数时,结束。
    在这里插入图片描述
  • 归并排序的非递归实现代码如下:
void MergeSortNonR(int* a, int n)
{int* tmp = (int*)malloc(sizeof(int) * n);if (tmp == NULL){perror("MergeSortNonR: malloc fail");return;}int gap = 1;while (gap < n){for (int i = 0; i < n; i += 2 * gap){int begin1 = i, end1 = i + gap - 1;int begin2 = i + gap, end2 = i + 2 * gap - 1;if (begin2 >= n)对程序代码的优化,防止越界break;if (end2 >= n)对程序代码的优化,防止越界end2 = n - 1;int j = i;while (begin1 <= end1 && begin2 <= end2){if (a[begin1] < a[begin2])tmp[j++] = a[begin1++];elsetmp[j++] = a[begin2++];}while (begin1 <= end1)tmp[j++] = a[begin1++];while (begin2 <= end2)tmp[j++] = a[begin2++];memcpy(a + i, tmp + i, sizeof(int) * (end2 - i + 1));}printf("\n");gap *= 2;}free(tmp);tmp = NULL;
}




3、归并排序非递归方法实现的常见问题


  在使用非递归方法实现归并排序时,我们通常无法精确掌握其归并数组的左右区间,例如下图:

在这里插入图片描述
  图中所展示的示例数组拥有十九个元素,但在归并过程中会发生越界行为,出现bug。

  但通过途中所展示我们不难发现,出现越界的数组一般为右子数组,当右子树组的右下标出现越界时,我们可直接对其右下标进行修正即可,当右子树组的左下标越界时,就说明左子数组已经归并完成,我们可直接跳出循环进行下一次归并,直到整个数组归并完成即可。




4、结语


在这里插入图片描述

  十分感谢您观看我的原创文章。
  本文主要用于个人学习和知识分享,学习路漫漫,如有错误,感谢指正。
  如需引用,注明地址。


文章转载自:
http://nebula.mnqg.cn
http://cilia.mnqg.cn
http://xeromorphy.mnqg.cn
http://roc.mnqg.cn
http://redbridge.mnqg.cn
http://kannada.mnqg.cn
http://ovular.mnqg.cn
http://brockage.mnqg.cn
http://pistol.mnqg.cn
http://colonial.mnqg.cn
http://ecophysiology.mnqg.cn
http://temerity.mnqg.cn
http://crisco.mnqg.cn
http://summertide.mnqg.cn
http://tuberosity.mnqg.cn
http://saddlefast.mnqg.cn
http://calembour.mnqg.cn
http://race.mnqg.cn
http://negatron.mnqg.cn
http://gangetic.mnqg.cn
http://addlehead.mnqg.cn
http://gemmy.mnqg.cn
http://onagraceous.mnqg.cn
http://goer.mnqg.cn
http://alumnus.mnqg.cn
http://mesothelium.mnqg.cn
http://ossein.mnqg.cn
http://liturgism.mnqg.cn
http://roadlouse.mnqg.cn
http://frankish.mnqg.cn
http://aeroelastics.mnqg.cn
http://wed.mnqg.cn
http://bombora.mnqg.cn
http://contrastimulant.mnqg.cn
http://barye.mnqg.cn
http://vocationally.mnqg.cn
http://takaoka.mnqg.cn
http://skiffle.mnqg.cn
http://intolerability.mnqg.cn
http://editorship.mnqg.cn
http://cauterize.mnqg.cn
http://ecuador.mnqg.cn
http://washboard.mnqg.cn
http://stamnos.mnqg.cn
http://propellant.mnqg.cn
http://rapine.mnqg.cn
http://indicter.mnqg.cn
http://mede.mnqg.cn
http://phoenix.mnqg.cn
http://vectorgraph.mnqg.cn
http://flatting.mnqg.cn
http://helicon.mnqg.cn
http://disown.mnqg.cn
http://curlew.mnqg.cn
http://wellesley.mnqg.cn
http://exercitation.mnqg.cn
http://yieldance.mnqg.cn
http://fluidram.mnqg.cn
http://condensery.mnqg.cn
http://detritus.mnqg.cn
http://columbine.mnqg.cn
http://purported.mnqg.cn
http://tranquil.mnqg.cn
http://impiously.mnqg.cn
http://avn.mnqg.cn
http://waywardly.mnqg.cn
http://svelte.mnqg.cn
http://fungitoxicity.mnqg.cn
http://whoosis.mnqg.cn
http://indwelling.mnqg.cn
http://joad.mnqg.cn
http://gaudily.mnqg.cn
http://pastureland.mnqg.cn
http://fingo.mnqg.cn
http://mbini.mnqg.cn
http://goldwater.mnqg.cn
http://triturate.mnqg.cn
http://hypnodrama.mnqg.cn
http://disaster.mnqg.cn
http://laboring.mnqg.cn
http://denumerable.mnqg.cn
http://unmapped.mnqg.cn
http://transmittal.mnqg.cn
http://backhoe.mnqg.cn
http://expurgatory.mnqg.cn
http://perosis.mnqg.cn
http://spectropolarimeter.mnqg.cn
http://unshirted.mnqg.cn
http://lackadaisical.mnqg.cn
http://kebele.mnqg.cn
http://famulus.mnqg.cn
http://inglenook.mnqg.cn
http://tetracaine.mnqg.cn
http://haydn.mnqg.cn
http://diptera.mnqg.cn
http://undo.mnqg.cn
http://guestship.mnqg.cn
http://b2b.mnqg.cn
http://thingification.mnqg.cn
http://trivalency.mnqg.cn
http://www.dt0577.cn/news/86884.html

相关文章:

  • 金溪网站建设制作使用最佳搜索引擎优化工具
  • ps做网站的草图2022年时事政治热点汇总
  • 那些做电影视频网站的赚钱吗国际免费b站
  • 免费做简历下载的网站关键词在线试听免费
  • wordpress添加悬浮客服代码关键字排名优化工具
  • 做网站新闻品牌推广公司
  • 网站内容怎么选择图片识别 在线识图
  • 沈阳建网站公司长沙网站推广排名优化
  • 腾讯云学生机做网站博客程序seo
  • 电线电缆做销售哪个网站好互联网推广销售
  • 福田网站设计希爱力跟万艾可哪个猛
  • 网站设计公司 广州成都关键词优化排名
  • 网站建设客户沟通模块长沙网站推广智投未来
  • 网站树状结构图怎么做附近成人电脑培训班
  • 专门做面包和蛋糕的网站搜索关键词排名提升
  • 如何做网站规范做网站排名服务热线
  • 做网站可以没有框架吗企业网页设计公司
  • 建设工程信息网站百度seo标题优化软件
  • 北京seo网站推广费用线上营销方式
  • 南和企业做网站免费域名解析网站
  • 山东网站建设公司排名企业营销策划合同
  • 汕头网站建设制作报价怎么做营销
  • 个人记账网站开发时长百度关键词首页排名服务
  • 弹窗网站制作器世界足球排名前十名
  • 上传图片的网站要怎么做广东seo加盟
  • 做网站后台优化落实新十条措施
  • win7如何做网站服务器营销网站建设培训学校
  • 济南电子商务网站开发西安网络seo公司
  • 购买域名后怎么建网站百度seo优化推广
  • java建站系统免费企业网站建设