iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >web如何实现归并排序
  • 485
分享到

web如何实现归并排序

2023-06-27 23:06:23 485人浏览 薄情痞子
摘要

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

这篇文章主要介绍了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 recursioGoes 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如何实现归并排序”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网精选频道,更多相关知识等着你来学习!

--结束END--

本文标题: web如何实现归并排序

本文链接: https://www.lsjlt.com/news/314330.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-14
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-14
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-14
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-14
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-14
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-14
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-14
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-14
    golang 数据库备份 mysql git 标准库
  • 如何在 Golang 中优雅地处理错误?
    在 go 中,优雅处理错误包括:使用 error 类型;使用 errors 包函数和类型;自定义错误类型;遵循错误处理模式,包括关闭资源、检查错误、打印错误信息和处理或返回错误。 在 ...
    99+
    2024-05-14
    golang 错误处理
  • 如何构建 Golang RESTful API,并使用中间件进行身份验证?
    本文介绍了如何构建 golang restful api。首先,通过导入必要的库、定义数据模型和创建路由来构建 restful api。其次,使用 go-chi/chigot 和 go-...
    99+
    2024-05-14
    golang git
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作