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

搞一个网站花多少钱增加网站广告位

搞一个网站花多少钱,增加网站广告位,专业做甜点的网站,推广网络一 简介 归并排序(Merge Sort) 的基本思想是: 首先将待排序文件看成 n n n 个长度为1的有序子文件, 把这些子文件两两归并, 得到 n 2 \frac{n}{2} 2n​ 个长度为 2 的有序子文件; 然后再把这 n 2 \frac{n}{2} 2n​ 个有序的子…

一 简介

归并排序(Merge Sort) 的基本思想是: 首先将待排序文件看成 n n n 个长度为1的有序子文件, 把这些子文件两两归并, 得到 n 2 \frac{n}{2} 2n 个长度为 2 的有序子文件;

然后再把这 n 2 \frac{n}{2} 2n 个有序的子文件两两归并, 如此反复,直到最后得到一个长度为 n n n 的有序文件为止, 这种排序方法称为二路归并排序

在本文中,我们讨论的归并排序特指二路归并排序. 看一个示意图:
在这里插入图片描述

二 实现过程

归并排序的核心操作是将数组中前后相邻的两个有序序列归并为一个有序序列.
以java为例,看一个demo。

public class MergeSort {public static void main(String[] args) {Integer[] array = new Integer[]{30,45,10,30,50};System.out.println("归并排序初始顺序\n"+ Arrays.toString(array));mergeSort(array);System.out.println("归并排序最后顺序\n"+Arrays.toString(array));}static void mergeSort(Integer[] arr) {sort(arr, 0, arr.length - 1);}/**** 将两个有序序列归并为一个有序序列*/static void sort(Integer[] arr, int low, int high) {if (low >= high) {return;}int mid = low + (high - low) / 2;sort(arr, low, mid);sort(arr, mid + 1, high);merge(arr, low, mid, high);}static void merge(Integer[] arr, int low, int mid, int high) {//定义了一个临时数组int[] temp = new int[high - low + 1];int i = low, j = mid + 1, k = 0;while (i <= mid && j <= high) {temp[k++] = arr[i] <= arr[j] ? arr[i++] : arr[j++];}while (i <= mid) {//将原数组从下标 low~middle 中剩余的复制到 temptemp[k++] = arr[i++];}while (j <= high) {//将原数组从下标 middle+1 ~ high 中剩余的复制到 temptemp[k++] = arr[j++];}for (i = 0; i < k; i++) {arr[low + i] = temp[i];}}
}

程序运行结果
在这里插入图片描述

归并排序算法

归并排序算法可看作递归算法, 虽然有的书写成不是递归算法同样实现了

三 步骤

第一步: 一趟归并排序的基本思想是, 在某趟归并中, 设各子文件长度为len(最后一个子文件的长度可能会小于len), 则归并前 R [ 1.. n ] R[1..n] R[1..n] 共有 n l e n \frac{n}{len} lenn 个有序子文件。 调用归并操作对子文件进行归并时, 必须对子文件的个数可能是奇数、最后一个子文件和长度可能小于 l e n len len 这两种特殊情况进行处理:

  1. 若子文件个数为奇数,则最后个子文件无需和其他子文件归并;
  2. 若子文件个数为偶数,则要注意最后一对子文件中后一个子文件的区间上界为 n n n.

第二步: 归并排序的过程需要进行 l o g 2 log_{2} log2 n {n} n 趟。 每一趟排序的操作,就是将两个有序子文件进行归并,
而每一对有序子文件归并时,
记录的比较次数均小于等于记录的移动次数,
记录移动的次数均等于文件中记录的个数
, 即每一趟归并的时间复杂度为 O ( n ) O(n) O(n)
因此归并排序的时间复杂度为 O ( n l o g 2 O(nlog_{2} O(nlog2 n n n ) ) ).
从上述例子可以看出, 空间复杂度为 O ( n ) O(n) O(n)

归并排序是稳定的, 因为在每两个有序子文件 归并时, 若分别在两个有序子文件中出现有相同关键字的记录时, 归并排序算法能够使前一个子文件中同一关键字的记录被先复制,后一子文件中同一关键字的记录后被复制,从而确保它们的相对次序不变。

四 归并算法的优缺点

优点

  1. 适合于大规模数据量,并且要求稳定。
  2. 在基于比较的算法中是最高效率。

缺点
需要数据集长度的辅助空间, 在一定程度上增加了空间复杂度。
如果初始数据几乎填满整个内存,归并排序可能无法工作。

综上,归并算法是应用于大规模数据集最好的排序算法

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

相关文章:

  • 常德网站建设求职简历图列表网站源码
  • 网站开发要考什么证西安有什么网页设计公司
  • 百容千域可以免费做网站吗公众号开发者id在哪里查看
  • 国外那些网站是做菠菜的做网站接单
  • 深圳外贸英文网站设计联系电话浙江省住房和城乡建设局网站
  • 怎么做火短视频网站简单网页设计模板源代码
  • 枞阳县建设局网站广州网站建设联享科技
  • 网站后台 英语宁夏做网站
  • 评价一个网站的好坏it软件外包
  • 大型网站服务器得多少钱网站建设需求调研通知
  • 装修公司网站模版网站建设广告
  • 广东省住房建设厅网站网页设计模板html代码地方介绍
  • 商业网站后缀名计算机培训班出来好找工作吗
  • 网站与网络的区别软文推广经典案例
  • 做网站时无法上传图片wordpress修改摘要字数
  • 高端企业网站模板网站开发的环境
  • 怎样把自己的网站做推广wordpress中文用户名注册
  • 吉林省工程建设标准网站手机网址导航主页哪个好
  • 中国重点城镇建设集团网站html购物网站模板
  • dw网页制作怎么插mp4视频中山网站搜索引擎优化
  • 企业建站找哪家wordpress 插件交互
  • 什么是同ip网站网页制作培训网站
  • 学习网站建设的步骤西宁城东区建设局公租房网站
  • 网站服务器和网站备案吗生成前端页面的网站
  • 电商网站代码模板网页版有意思的游戏排行榜
  • 家政的网站怎么做黄山做网站公司
  • 国内课程网站建设现状大型网站技术方案
  • 山西省建设厅网站见证员证书宋来增免费h5制作app平台
  • 教育类企业网站竹子建站加盟咨询
  • 建设响应式网站有哪些好处网站备案起名要求