博客
关于我
程序设计入门21 堆排序与插入排序
阅读量:391 次
发布时间:2019-03-05

本文共 2228 字,大约阅读时间需要 7 分钟。

为了判断给定的排序结果是插入排序还是堆排序,并模拟下一次迭代,我们可以按照以下步骤进行:

判断排序方法

  • 插入排序的特征:每次插入一个元素到已排序位置,结果序列的已排序部分是递增的,且未排序部分的元素尚未被处理。
  • 堆排序的特征:每次移动未排序部分的最大元素到已排序位置,结果序列的已排序部分是递增的,且未排序部分可能包含较小的元素。
  • 通过观察结果序列的结构,判断已排序部分是否是递增的,并比较未排序部分是否有最大值已经被移动到已排序位置。如果满足堆排序的特征,则为堆排序,否则为插入排序。

    模拟下一次迭代

    根据判断结果,模拟下一次迭代:

  • 插入排序

    • 取出未排序部分的下一个元素。
    • 插入到已排序位置,找到正确的位置。
  • 堆排序

    • 构建一个堆结构,每次取出堆顶(最大值),插入到已排序位置。
  • 代码实现

    def is_sorted(arr):    for i in range(len(arr)-1):        if arr[i] > arr[i+1]:            return False    return Truedef insertion_sort(arr):    sorted_part = []    unsorted_part = arr.copy()    while unsorted_part:        element = unsorted_part.pop(0)        for i in range(len(sorted_part)+1):            if element <= sorted_part[i]:                sorted_part.insert(i, element)                break    return sorted_partdef heap_sort(arr):    n = len(arr)    heap = [0] * n    for i in range(n):        heap[i] = arr[i]    # Build heap    for i in range(n, 1, -1):        parent = i // 2        if heap[parent] < heap[i]:            heap[parent], heap[i] = heap[i], heap[parent]    # Sort the heap    sorted_part = []    while heap:        max_val = heap[0]        sorted_part.append(max_val)        heap[0] = 0        i = 1        while i < len(heap) and heap[i] > 0:            if heap[i//2] < heap[i]:                heap[i//2], heap[i] = heap[i], heap[i//2]            i += 1    return sorted_partdef main():    import sys    input = sys.stdin.read().split()    ptr = 0    N = int(input[ptr])    ptr += 1    initial = list(map(int, input[ptr:ptr+N]))    ptr += N    target = list(map(int, input[ptr:ptr+N]))    ptr += N        if is_sorted(target):        print("Heap Sort")        sorted_part = heap_sort(initial)        next_target = sorted_part + initial[N - len(sorted_part) : ]        print(' '.join(map(str, next_target)))    else:        print("Insertion Sort")        sorted_part = insertion_sort(initial)        next_target = sorted_part + initial[N - len(sorted_part) : ]        print(' '.join(map(str, next_target)))    if __name__ == "__main__":    main()

    解释

  • is_sorted函数:检查数组是否已经排序。
  • insertion_sort函数:模拟插入排序,逐个插入元素到已排序位置。
  • heap_sort函数:模拟堆排序,构建堆并每次移动最大值到已排序位置。
  • main函数:读取输入,判断排序方法,并模拟下一次迭代,输出结果。
  • 该代码首先读取输入,判断排序方法,然后模拟下一次迭代,输出结果。通过判断已排序部分是否是递增的来确定排序方法,并根据方法模拟下一步。

    转载地址:http://bolwz.baihongyu.com/

    你可能感兴趣的文章
    OSG学习:场景图形管理(三)——多视图相机渲染
    查看>>
    OSG学习:场景图形管理(二)——单窗口多相机渲染
    查看>>
    OSG学习:场景图形管理(四)——多视图多窗口渲染
    查看>>
    OSG学习:新建C++/CLI工程并读取模型(C++/CLI)——根据OSG官方示例代码初步理解其方法
    查看>>
    Sql 随机更新一条数据返回更新数据的ID编号
    查看>>
    OSG学习:空间变换节点和开关节点示例
    查看>>
    OSG学习:纹理映射(一)——多重纹理映射
    查看>>
    OSG学习:纹理映射(七)——聚光灯
    查看>>
    OSG学习:纹理映射(三)——立方图纹理映射
    查看>>
    OSG学习:纹理映射(二)——一维/二维/简单立方图纹理映射
    查看>>
    OSG学习:纹理映射(五)——计算纹理坐标
    查看>>
    OSG学习:纹理映射(六)——灯光
    查看>>
    OSG学习:纹理映射(四)——三维纹理映射
    查看>>
    OSG:从源码看Viewer::run() 一
    查看>>
    osi 负载均衡
    查看>>
    OSI七层模型与TCP/IP五层模型(转)
    查看>>
    OSI七层模型与TCP/IP四层与五层模型详解
    查看>>
    OSI七层模型的TCP/IP模型都有哪几层和他们的对应关系?
    查看>>
    OSI操作系统(NETBASE第八课)
    查看>>
    OSM数据如何下载使用(地图数据篇.11)
    查看>>