首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    堆排序

    剩下的排序就很简单了,按照之前的思路,先建立一个小根堆,然后不断地删除堆顶最小元素,删除N-1次就OK了 只需删除N-1次,剩下的那个自然是最大的,所以我循环N-1次 恩恩,很好,这个排序就是今天要给你说的另一个排序:堆排序...谦子暗自惊叹老师的功力,不知不觉又学到了一个排序方法 时间复杂度 那你分析一下这个堆排序的时间复杂度吧 看到数学头疼的可以直接跳过看结论 谦子还没缓过神,又来了一个最让他头疼的时间复杂度 这个。。。...则相当于进行了n-1次sink操作 则一共花费的代价为:(n-1)*lgn ~ nlgn 故时间复杂度为O(nlgn) 两个步骤相加的复杂度为:O(n)+O(nlgn),O(nlgn)复杂度高于O(n),所以堆排序的时间复杂度为...O(nlgn) 哦,这样啊,懂了 那你说说堆排序是不是稳定的 不是稳定的,就拿5,7,13,5,这个序列来说吧,我用大根堆的结构排序,排序前后两个5的位置会发生变化 谦子说着说着画了一个图 初始状态的5

    62290

    堆排序

    注释解释的完整堆排序代码 #include #include using namespace std; //调整为大顶堆...防止被替换掉之后,无法找回替换前的根节点 temp = arr[i];//保存当前根节点值 //这里j首先指向根节点的左孩子 //外层for循环是防止在进行根和孩子交换后,还需要对以孩子节点为根的子树进行堆排序操作...位置 //因为交换后,原先根节点应该移动到其较大孩子的位置 i = j; } //并且下面这条更新原先根位置的赋值语句必须写在for循环之外 //因为会存在需要对以孩子节点为根的子树进行堆排序操作...:" << endl; display(arr, 8); HeapSort(arr, 8); cout 堆排序后:" << endl; display(arr,8); } int...:" << endl; display(arr, 8); HeapSort(arr, 8); cout 堆排序后:" << endl; display(arr,8); } int

    14510
    领券