我的编程空间,编程开发者的网络收藏夹
学习永远不晚

web如何实现归并排序

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

web如何实现归并排序

这篇文章主要介绍了web如何实现归并排序,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(divide-and-conquer)策略(分治法将问题(divide)成一些小的问题然后递归求解,而**治(conquer)**的阶段则将分的阶段得到的各答案”修补”在一起,即分而治之)。

web如何实现归并排序

作为一种典型的分而治之思想的算法应用,归并排序的实现由两种方法:

  1. 自上而下的递归(所有递归的方法都可以用迭代重写,所以就有了第 2 种方法);
  2. 自下而上的迭代;

在《数据结构与算法 JavaScript 描述》中,作者给出了自下而上的迭代方法。但是对于递归法,作者却认为:

However, it is not possible to do so in JavaScript, as the recursion goes too deep for the language to handle.然而,在 JavaScript 中这种方式不太可行,因为这个算法的递归深度对它来讲太深了。

说实话,我不太理解这句话。意思是 JavaScript 编译器内存太小,递归太深容易造成内存溢出吗?还望有大神能够指教。

和选择排序一样,归并排序的性能不受输入数据的影响,但表现比选择排序好的多,因为始终都是 O(nlogn) 的时间复杂度。代价是需要额外的内存空间。

算法步骤

  1. 申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列;
  2. 设定两个指针,最初位置分别为两个已经排序序列的起始位置;
  3. 比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置;
  4. 重复步骤 3 直到某一指针达到序列尾;
  5. 将另一序列剩下的所有元素直接复制到合并序列尾。

动图演示

web如何实现归并排序

代码实现

JavaScript

实例

function mergeSort(arr) {  // 采用自上而下的递归方法   var len = arr.length;   if(len return arr;   }   var middle = Math.floor(len / 2),       left = arr.slice(0, middle),       right = arr.slice(middle);   return merge(mergeSort(left), mergeSort(right));}function merge(left, right){   var result = [];   while (left.length && right.length) {       if (left[0] else {           result.push(right.shift());       }   }   while (left.length)       result.push(left.shift());   while (right.length)       result.push(right.shift());   return result;}

Python

实例

def mergeSort(arr):   import math   if(len(arr)return arr   middle = math.floor(len(arr)/2)   left, right = arr[0:middle], arr[middle:]   return merge(mergeSort(left), mergeSort(right))def merge(left,right):   result = []   while left and right:       if left[0] else:           result.append(right.pop(0));   while left:       result.append(left.pop(0))   while right:       result.append(right.pop(0));   return result

Go

实例

func mergeSort(arr []int) []int {       length := len(arr)       if length return arr       }       middle := length / 2       left := arr[0:middle]       right := arr[middle:]       return merge(mergeSort(left), mergeSort(right))}func merge(left []int, right []int) []int {       var result []int       for len(left) != 0 && len(right) != 0 {               if left[0] else {                       result = append(result, right[0])                       right = right[1:]               }       }       for len(left) != 0 {               result = append(result, left[0])               left = left[1:]       }       for len(right) != 0 {               result = append(result, right[0])               right = right[1:]       }       return result}

Java

实例

public class MergeSort implements IArraySort {   @Override   public int[] sort(int[] sourceArray) throws Exception {       // 对 arr 进行拷贝,不改变参数内容       int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);       if (arr.length return arr;       }       int middle = (int) Math.floor(arr.length / 2);       int[] left = Arrays.copyOfRange(arr, 0, middle);       int[] right = Arrays.copyOfRange(arr, middle, arr.length);       return merge(sort(left), sort(right));   }   protected int[] merge(int[] left, int[] right) {       int[] result = new int[left.length + right.length];       int i = 0;       while (left.length > 0 && right.length > 0) {           if (left[0] else {               result[i++] = right[0];               right = Arrays.copyOfRange(right, 1, right.length);           }       }       while (left.length > 0) {           result[i++] = left[0];           left = Arrays.copyOfRange(left, 1, left.length);       }       while (right.length > 0) {           result[i++] = right[0];           right = Arrays.copyOfRange(right, 1, right.length);       }       return result;   }}

PHP

实例

function mergeSort($arr){   $len = count($arr);   if ($len return $arr;   }   $middle = floor($len / 2);   $left = array_slice($arr, 0, $middle);   $right = array_slice($arr, $middle);   return merge(mergeSort($left), mergeSort($right));}function merge($left, $right){   $result = [];   while (count($left) > 0 && count($right) > 0) {       if ($left[0] $right[0]) {           $result[] = array_shift($left);       } else {           $result[] = array_shift($right);       }   }   while (count($left))       $result[] = array_shift($left);   while (count($right))       $result[] = array_shift($right);   return $result;}

C

实例

int min(int x, int y) {   return x for (seg = 1; seg for (start = 0; start while (start1 while (start1 while (start2 if (a != arr) {       int i;       for (i = 0; i

递归版:

实例

void merge_sort_recursive(int arr[], int reg[], int start, int end) {   if (start >= end)       return;   int len = end - start, mid = (len >> 1) + start;   int start1 = start, end1 = mid;   int start2 = mid + 1, end2 = end;   merge_sort_recursive(arr, reg, start1, end1);   merge_sort_recursive(arr, reg, start2, end2);   int k = start;   while (start1 while (start1 while (start2 for (k = start; k

C++

迭代版:

实例

template // 整數或浮點數皆可使用,若要使用物件(class)時必須設定"小於"(for (int seg = 1; seg for (int start = 0; start while (start1 while (start1 while (start2 if (a != arr) {       for (int i = 0; i

递归版:

实例

void Merge(vector &Array, int front, int mid, int end) {   // preconditions:   // Array[front...mid] is sorted   // Array[mid+1 ... end] is sorted   // Copy Array[front ... mid] to LeftSubArray   // Copy Array[mid+1 ... end] to RightSubArray   vector LeftSubArray(Array.begin() + front, Array.begin() + mid + 1);   vector RightSubArray(Array.begin() + mid + 1, Array.begin() + end + 1);   int idxLeft = 0, idxRight = 0;   LeftSubArray.insert(LeftSubArray.end(), numeric_limits::max());   RightSubArray.insert(RightSubArray.end(), numeric_limits::max());   // Pick min of LeftSubArray[idxLeft] and RightSubArray[idxRight], and put into Array[i]   for (int i = front; i if (LeftSubArray[idxLeft] else {           Array[i] = RightSubArray[idxRight];           idxRight++;       }   }}void MergeSort(vector &Array, int front, int end) {   if (front >= end)       return;   int mid = (front + end) / 2;   MergeSort(Array, front, mid);   MergeSort(Array, mid + 1, end);   Merge(Array, front, mid, end);}

C#

实例

public static List sort(List lst) {   if (lst.Count return lst;   int mid = lst.Count / 2;   List left = new List();  // 定义左侧List   List right = new List(); // 定义右侧List   // 以下兩個循環把 lst 分為左右兩個 List   for (int i = 0; i for (int j = mid; j return merge(left, right);}////// 合併兩個已經排好序的List////// 左側List/// 右側List///static List merge(List left, List right) {   List temp = new List();   while (left.Count > 0 && right.Count > 0) {       if (left[0] else {           temp.Add(right[0]);           right.RemoveAt(0);       }   }   if (left.Count > 0) {       for (int i = 0; i if (right.Count > 0) {       for (int i = 0; i return temp;}

Ruby

实例

def merge list return list if list.size # Merge lambda { |left, right|   final = []   until left.empty? or right.empty?     final if left.first else right.shift end   end   final + left + right }.call merge(list[0...pivot]), merge(list[pivot..-1])end

感谢你能够认真阅读完这篇文章,希望小编分享的“web如何实现归并排序”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

web如何实现归并排序

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

web如何实现归并排序

这篇文章主要介绍了web如何实现归并排序,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。归并排序(MERGE-SORT)是利用归并的思想实现的排序方法,该算法采用经典的分治(d
2023-06-27

web开发中如何实现归并排序

小编给大家分享一下web开发中如何实现归并排序,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!归并排序归并排序(Merge sort)是建立在归并操作上的一种有效的
2023-06-19

C#如何实现归并排序

这篇文章主要介绍“C#如何实现归并排序”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C#如何实现归并排序”文章能帮助大家解决问题。什么是归并?即将两个有序的数组归并成一个更大的有序数组。什么是归并排
2023-06-30

php如何实现并归排序

今天小编给大家分享一下php如何实现并归排序的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。php实现并归排序的方法:1、创建
2023-07-04

归并排序python实现

归并排序归并排序在于把序列拆分再合并起来,使用分治法来实现,这就意味这要构造递归算法首先是一个例子原序先通过一半一半的拆分,然后:然后再一步一步的向上合并,在合并的过程中完成了排序,合并排序算法如下:def merge(s1,s2,s):
2023-01-31

如何在python中实现归并排序

这期内容当中小编将会给大家带来有关如何在python中实现归并排序,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3、网络
2023-06-14

C++如何实现归并排序算法

这篇文章将为大家详细讲解有关C++如何实现归并排序算法,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。归并算法开始首先要对一段要有序的数字进行排序void merg_sort(int* a, int fbe
2023-06-25

如何利用java实现归并排序

什么是归并排序?归并排序是利用递归与分治的技术将数据序列划分为越来越小的半子表,再对半子表排序,最后再用递归方法将排好序的半子表合并成越来越大的有序序列。核心思想将两个有序的数列合并成一个大的有序的序列。通过递归,层层合并,即为归并。(推荐教程:java快速入
如何利用java实现归并排序
2018-05-27

Python3实现快速排序、归并排序、堆

# -*- coding: utf-8 -*-# @Time : 2019-03-26 16:46# @Author : Jayce Wong# @ProjectName : leetcode# @FileNa
2023-01-31

TypeScript怎么实现归并排序

这篇文章主要介绍“TypeScript怎么实现归并排序”,在日常操作中,相信很多人在TypeScript怎么实现归并排序问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”TypeScript怎么实现归并排序”的疑
2023-07-05

python编程实现归并排序

因为上个星期leetcode的一道题(Median of Two Sorted Arrays)所以想仔细了解一下归并排序的实现。 还是先阐述一下排序思路: 首先归并排序使用了二分法,归根到底的思想还是分而治之。拿到一个长数组,将其不停的分为
2022-06-04

Java实现插入排序,希尔排序和归并排序

这篇文章主要为大家详细介绍了插入排序,希尔排序和归并排序的多种语言的实现(JavaScript、Python、Go语言、Java),感兴趣的小伙伴可以了解一下
2022-12-22

Java排序算法之归并排序简单实现

算法描述:对于给定的一组记录,首先将每两个相邻的长度为1的子序列进行归并,得到 n/2(向上取整)个长度为2或1的有序子序列,再将其两两归并,反复执行此过程,直到得到一个有序序列。package sorting;/** * 归并排序 * 平
2023-05-30

Java归并排序和快速排序怎么实现

本篇内容介绍了“Java归并排序和快速排序怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!归并排序// 归并排序 public
2023-06-04

Java的堆排序、快速排序、归并排序怎么实现

本文小编为大家详细介绍“Java的堆排序、快速排序、归并排序怎么实现”,内容详细,步骤清晰,细节处理妥当,希望这篇“Java的堆排序、快速排序、归并排序怎么实现”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。堆排序
2023-06-26

C++归并排序算法怎么实现

这篇文章主要介绍“C++归并排序算法怎么实现”,在日常操作中,相信很多人在C++归并排序算法怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++归并排序算法怎么实现”的疑惑有所帮助!接下来,请跟着小编
2023-06-26

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录