- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我们构建堆时,数组中的元素会根据它是最大堆还是最小堆以特定顺序(升序或降序)排列。那么堆排序在构建堆本身时有什么用呢?以更小的时间复杂度按排序顺序排列元素?
void build_heap (int Arr[ ])
{
for(int i = N/2-1 ; i >= 0; i-- )
{
down_heapify (Arr, i, N);
}
}
void heap_sort(int Arr[], int N)
{
build_heap(Arr);
for(int i = N-1; i >= 1; i--)
{
swap(Arr[i], Arr[0]);
down_heapify(Arr, 0, i+1);
}
}
最佳答案
堆排序是一种算法,可以概括为两个步骤:
堆本身不是排序数组。
让我们看一个例子:
[9, 7, 3, 5, 4, 2, 0, 6, 8, 1] # unsorted array
convert into heap
[9, 8, 3, 7, 4, 2, 0, 6, 5, 1] # array representing a max-heap
sort
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9] # sorted array
如果仔细观察,您会注意到我的示例中的第二个数组(代表堆)没有完全排序。元素的顺序看起来不像原始未排序数组那样随机;它们看起来几乎是按降序排列的;但它们并没有完全分类。数组中3在7之前,0在6之前。
那么什么是堆?
请注意,在上一节中,我区分了“堆”和“表示堆的数组”。先说什么是堆,再说什么是代表堆的数组。
最大堆是一个二叉树,其节点上有值,它满足以下两个属性:
我举的例子中,构造的堆是这个:
9
/ \
8 3
/ \ / \
7 4 2 0
/ \ / \ / \ / \
6 5 1
你可以检查这个二叉树是否满足堆的两个属性:每个子节点的值都比它的父节点低,所有分支的长度几乎相同,每个分支总是有 4 或 3 个值,最长的分支在左边,最短的分支在右边。
将二叉树存储到数组中通常很不方便,二叉树通常使用指针实现,有点像链表。然而,堆是一种非常特殊的二叉树,其“几乎完整”的特性对于将其实现为数组非常有用。
我们所要做的就是从左到右逐行读取值。在上面的堆中,我们有四行:
9
8 3
7 4 2 0
6 5 1
我们只需将这些值按顺序存储在一个数组中:
[9, 8, 3, 7, 4, 2, 0, 6, 5, 1]
请注意,这正是我文章开头的第一步堆排序之后的数组。
在这个数组表示中,我们可以使用位置来确定哪个节点是哪个节点的子节点:位置 i
的节点有两个子节点,它们位于位置 2*i+ 1
和 2*i+2
。
此数组不是排序数组。但它代表一个堆,我们可以很容易地使用它来生成一个排序数组,在 n log(n) 操作中,通过重复提取最大元素。
如果堆排序是用外部二叉树实现的,那么我们可以使用最大堆或最小堆,并通过重复选择最大元素或最小元素来对数组进行排序。但是,如果您尝试就地实现堆排序,将堆作为数组存储在正在排序的数组中,您会注意到使用最大堆比使用最小堆更方便,在order 通过重复选择最大元素并将其移动到数组末尾来按升序对元素进行排序。
关于algorithm - 堆排序的目的是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69062064/
我正致力于通过 OAuth 合并外部 API,但对 expires_in 属性的用途有点迷惑。通过阅读,应该对 api token 的使用进行防御性编码,因为您应该预料到 token 在任何时候都可能
有人可以概述或总结一下 Spring 框架上下文中 bean 的用途吗? 我了解标准的 Java bean(没有 arg 构造函数、getter/setter,通常是序列化的),但 Spring be
使用 OpenGL 4.1 和 ARB_separate_shader_objects,我们能够在着色器程序中存储着色管道的不同阶段。众所周知,要使用这些,我们需要将它们附加到程序管道对象,然后绑定(
正如我从文档中了解到的那样,“MoveIteratorFactory”的目的是生成每一步都需要执行的 Action 。 “getSize”方法的移动子集有多大? “createOriginalMove
请解释 CMakeLists.txt 中这一行的目的是什么: 包括(InstallRequiredSystemLibraries) 我在 CMake 示例中看到这一行,但找不到好的解释,为什么我需要它
这里是新手。我仍在尝试理解在多个布局中运行单个进程或目的的概念。 例如,我想在我的申请中添加“提交后”功能。有一个包含标题、内容等文本框的主布局,以及一个链接到另一个布局以选择类别的按钮。我的问题是,
我在看 Box Oauth2.0 View Controller : https://github.com/box/box-ios-sdk-v2/blob/master/BoxSDK/OAuth2/B
我编写了一个将字符串复制到系统剪贴板的 Java 应用程序。构造函数使用 Clipboard.setContents(Transferable contents, ClipboardOwner own
阅读此文后:http://sourcemaking.com/design_patterns/command 我还是不太明白为什么我们需要这个。 最佳答案 想法是,如果命令被封装为对象,那么这些命令可以
我知道 c++ 中的模板是做什么的,但是今天我看到了一些奇怪的代码: template <> void swap(foo &a, foo &b) { a.name = b.name; a.
我不太明白 C# Collections 中 IEnumerator 的用途是什么。它的用途是什么,为什么要使用它? 我试着在线查看 http://msdn.microsoft.com/en-us/l
不幸的是,我今天做了一些代码考古(同时重构了一些旧的危险代码)并发现了这样的小化石: # line 7 "foo.y" 能在里面找到如此古老的宝藏,我完全惊呆了。我在 C 编程的网站上阅读了它。然而,
您能否澄清一下此注释的实际用途? - 如果我们没有使用数据库中的 SQL 表定义定义相应的约束,会发生什么情况。当我们尝试插入时,hibernate 会检查唯一性吗?或者这就是DB的目的吗?如果 hi
我在视频教程中看到过这段代码: const navToggle = ["Menu"].join(""); $(".site-header").prepend(navToggle); 我明白它的基本作用
我想知道这个成员函数的 scroll_to(TextBuffer::iterator& iter, double within_margin = 0)参数 within_margin。 API 是这样
我想知道是否可以将子目录提交到目录例如,假设您有 site.com/directory 可以将子目录提交到目录。我即将开始为希望她的网站在搜索引擎中排名靠前的客户进行一些搜索引擎优化。我知道实现此目的
STL 迭代器的用途是什么?为什么程序员要创造这个概念? 最佳答案 迭代器允许您将算法与容器分开。只要您有开始和结束迭代器,并且知道迭代器的功能(随机访问等),您就可以在迭代器指定的范围内进行操作。例
NSData *responseData = [NSURLConnection sendSynchronousRequest:theRequest returningResponse:&respons
我正在编写代码,使用通用的 linux i2c 驱动程序 linux/i2c-dev.h 实现一个简单的 i2c 读/写功能 我对 ioctl 感到困惑:I2C_SLAVE 内核文档说明如下: You
在尝试克隆可变集合时,我最初的方法是对 mutable.Cloneable 特征使用 clone() 方法。但是,这取决于创建引用副本的 java.Object.clone 实现,而不是深拷贝。通过测
我是一名优秀的程序员,十分优秀!