博客
关于我
程序设计入门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/

    你可能感兴趣的文章
    Objective-C实现longestCommonSubsequence最长公共子序列算法(附完整源码)
    查看>>
    Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现lorenz transformation 洛伦兹变换算法(附完整源码)
    查看>>
    Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
    查看>>
    Objective-C实现lowest common ancestor最低共同祖先算法(附完整源码)
    查看>>
    Objective-C实现LRU 缓存算法(附完整源码)
    查看>>
    Objective-C实现LRU缓存(附完整源码)
    查看>>
    Objective-C实现lstm prediction预测算法(附完整源码)
    查看>>
    Objective-C实现lucas数列算法(附完整源码)
    查看>>
    Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
    查看>>
    Objective-C实现LZW编码(附完整源码)
    查看>>
    Objective-C实现MAC桌面暗水印(附完整源码)
    查看>>
    Objective-C实现mandelbrot曼德勃罗特集算法(附完整源码)
    查看>>
    Objective-C实现markov chain马尔可夫链算法(附完整源码)
    查看>>
    Objective-C实现MATLAB中Filter函数功能(附完整源码)
    查看>>
    Objective-C实现matrix exponentiation矩阵求幂算法(附完整源码)
    查看>>
    Objective-C实现MatrixMultiplication矩阵乘法算法 (附完整源码)
    查看>>
    Objective-C实现max non adjacent sum最大非相邻和算法(附完整源码)
    查看>>
    Objective-C实现max subarray sum最大子数组和算法(附完整源码)
    查看>>
    Objective-C实现max sum sliding window最大和滑动窗口算法(附完整源码)
    查看>>