首页 > 编程语言 >数据结构与算法之归并排序,以及它的代码实现与事例

数据结构与算法之归并排序,以及它的代码实现与事例

时间:2024-06-09 11:29:50浏览次数:25  
标签:归并 排序 数组 元素 合并 有序 数据结构

目录

前言

定义

策略

代码

实现

结果

结束语


前言

今天是坚持写博客的第22天,我们来看看数据结构与算法当中的归并排序。


定义

首先我们来看看什么是归并排序?

归并排序(Merge Sort)是一种分治思想的排序算法。它将待排序的数组分成若干个子数组,每个子数组都是有序的,然后再将有序子数组合并成一个大的有序数组,直到合并为1个完整的数组。

策略

接下来是归并排序的策略实现。

合并是归并排序中的关键步骤。假设我们有两个已排序的子数组A和B,我们要将它们合并成一个大的有序数组C。合并的基本思想是,比较两个子数组的第一个元素,将较小的元素添加到C中,并移动相应子数组的指针到下一个位置。然后,重复这个过程,直到其中一个子数组的所有元素都被添加到C中,最后将另一个子数组的剩余元素添加到C的末尾。

具体方法:

  1. 分解:将待排序的数组分解成两个较小的子数组,直到子数组的大小为1。子数组的大小为1时,我们认为它是已排序的(或称为“有序子数组”)。
  2. 递归合并:递归地对子数组进行排序。将已排序的子数组合并成一个大的有序数组,直到合并为1个完整的数组。

假设我们有一个数组:[38,27, 43,3, 9, 82, 10],我们现对他进行分解:将数组分解成单个元素的子数组。

然后对数组进行合并与排序,并在合并的过程中进行排序,例如38和27一组,在合并完成后就变成[27,38]。其他的也一样,同理。将两个两元素的数组排序时,也和单元素数组合并一样操作即可。

代码

接下来就是大家期待已久的代码实现,实现和运行结果如下: 

实现

def merge_sort(arr):  
    if len(arr) <= 1:  
        return arr  
  
    # 分解  
    mid = len(arr) // 2  
    left = arr[:mid]  
    right = arr[mid:]  
  
    # 递归进行排序  
    left = merge_sort(left)  
    right = merge_sort(right)  
  
    # 合并  
    return merge(left, right)  
  
  
def merge(left, right):  
    merged = []  
    left_index = 0  
    right_index = 0  
  
    # 比较两个数组的元素,并将较小的元素添加到merged数组中  
    while left_index < len(left) and right_index < len(right):  
        if left[left_index] <= right[right_index]:  
            merged.append(left[left_index])  
            left_index += 1  
        else:  
            merged.append(right[right_index])  
            right_index += 1  
  
    # 如果left数组还有剩余元素,将它们添加到merged数组中  
    while left_index < len(left):  
        merged.append(left[left_index])  
        left_index += 1  
  
    # 如果right数组还有剩余元素,将它们添加到merged数组中  
    while right_index < len(right):  
        merged.append(right[right_index])  
        right_index += 1  
  
    return merged  
  
  
# 示例  
arr = [38, 27, 43, 3, 9, 82, 10]  
sorted_arr = merge_sort(arr)  
print(sorted_arr)  # 输出: [3, 9, 10, 27, 38, 43, 82]

结果


结束语

今天对归并排序的解释就到这里,希望可以对大家有帮助。如果对您有帮助,希望您可以给我一个点赞、关注和收藏,这对我很重要,谢谢!

标签:归并,排序,数组,元素,合并,有序,数据结构
From: https://blog.csdn.net/m0_75262255/article/details/139552829

相关文章

  • 数据结构学习笔记-堆排序
    堆排序算法的设计与分析问题描述:设计并分析堆排序【前置知识:什么是堆?】堆(Heap)是一种特殊的树形数据结构,它满足以下两个条件之一:最大堆(MaxHeap):每个节点的值都大于或等于其子节点的值。换句话说,根节点的值是整个堆中最大的。最小堆(MinHeap):每个节点的值都小于或等于其......
  • Python数据结构解析:从基本语法到实战应用,提升代码效率与性能
    基本语法Python提供了多种内置的数据结构,包括列表(List)、元组(Tuple)、集合(Set)、字典(Dictionary)等。这些数据结构具有不同的特点和用途,可以根据需求选择合适的数据结构。1.列表(List)列表是Python中最常用的数据结构之一,用于存储一系列元素,可以是不同类型的数据。列表使用......
  • 8645 归并排序(非递归算法)
    Description用函数实现归并排序(非递归算法),并输出每趟排序的结果输入格式第一行:键盘输入待排序关键的个数n第二行:输入n个待排序关键字,用空格分隔数据输出格式每行输出每趟排序的结果,数据之间用一个空格分隔输入样例105480932671输出样例4508392......
  • 常见排序算法
    文章目录冒泡排序插入排序希尔排序选择排序堆排快速排序递归版前后指针版用栈实现快排归并排序用循环方式归并冒泡排序冒泡排序应该是最先学到的一种排序算法,也是最简单的一种排序算法。思路就是,从最前面开始两两比较大的放后面。但是要注意一个问题每走一趟就把......
  • 【排序算法】快速排序
    一、定义:        快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法(也叫Hoare排序),是一种基于分治的排序方。其基本原理是将待排序的数组通过一趟排序分成两个独立的部分,其中一部分的所有数据比另一部分的所有数据都要小,然后再按此方法对这两部分数据分别进......
  • 数据结构(C语言严蔚敏版)——第二章 线性表
    前言:    对这一章节的学习,我深有体会,只有把链表这一重点弄清楚,才算开始真正的正式学习数据结构,刚开始学习链表的朋友可能会感到有点绕脑,但是当你掌握链表以后,你会发现其实原来学习编程还是很有意思的,慢慢在学习中找到成就感,不断收获。   当然,这章的重点还是在......
  • Java——数组排序
     一、排序介绍1、排序的概念排序是将多个数据按照指定的顺序进行排列的过程。2、排序的种类排序可以分为两大类:内部排序和外部排序。3、内部排序和外部排序1)内部排序内部排序是指数据在内存中进行排序,适用于数据量较小的情况。数据可以完全装入内存。常见的内部排序算......
  • C++U7-08-拓扑排序
    拓扑:是指把实体抽象成与其大小形状无关的点,把连接实体的线路抽象成线,研究这些点线之间的相连关系。而表示点和线之间关系的图就被称为拓扑结构图。 拓扑学原本是一个数学概念,描述的是几何图形或空间在连续改变形状后还能保持不变的性质,它只考虑物体间的位置关系而......
  • 二叉排序树--c++
    【相关知识】二叉排序树(也称二叉查找树):或者是一棵空的二叉树,或者是具有下列性质的二叉树:⑴若它的左子树不空,则左子树上所有结点的值均小于根结点的值;⑵若它的右子树不空,则右子树上所有结点的值均大于根结点的值;⑶它的左右子树也都是二叉排序树。【题目描述】①给定......
  • 华为OD刷题C卷 - 每日刷题 8(整形数组按个位值排序,停车场车辆统计)
    两段代码分别解决了两个不同的算法问题,下面是对它们的概述:1、(整形数组按个位值排序):这段代码是解决“整形数组按个位值排序”的问题。它提供了一个Java类Main,其中包含main方法,用于读取输入、执行排序并打印结果。代码首先使用Scanner从标准输入读取一行文本,该文本包含一个......