- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
最近我在 stackoverflow 上发布了一个问题 Time complexity issues with multimap我得到了一些很好的答案,这些答案让我想到了堆的使用,奇怪的是我以前根本没有使用过。我创建了一个使用最小堆和最大堆重写的新程序。它工作得很好,因为它比我为这个问题实现的任何其他程序都快得多。唯一的问题是它偶尔会抛出一些错误的答案。我回去做了很多调试。我意识到问题出在我的堆的组织上。它并没有像我认为的那样被排序和分发,使用 push_heap 和 pop_heap 进行比较操作。此外,当我尝试在 Visual Studio 上运行该程序时,我最终会看到那里抛出了很多断言错误。我尝试在 cplusplus.com 和 cppreference.com 上阅读更多关于堆及其方法的内容。我想我可能没有正确理解某些东西,因此遇到了更多问题。
让我困惑的第一件事是 push_heap。我的理解是这样的:push_heap 有两个参数,默认 它将least 值推到 last-1 位置。它仅在第一个参数小于第二个参数时才这样做,否则保持不变。它基本上保持正常堆的顺序。第三个可选参数是一个比较运算符,它可以用作 greater() ,然后将更大的元素推到 last-1 位置。
没有意义的是,如果我在 vector 中动态插入或删除数字,我将无法保持此顺序。如果我希望 vector 按升序排列,我会使用更大的操作来继续插入堆,以便值升序。但是当您第一次看到 push_heap 方法时会感到困惑,因为它看起来很像其他一些算法函数,这些函数在 range 数字中执行,例如:
std::unique (myvector.begin(), myvector.end(), myfunction);
push_heap 不做。它不会对 vector 范围中的所有数字做这个比较操作,我一开始没看懂。
在发现 push_heap 并没有真正保持我的 vector 排序之后,我不得不保持我的 vector 排序以便使用二进制搜索。我使用了 sort_heap,但这会使程序变慢,速度不够快。
此外,我发现有时 push_heap 会在奇怪的情况下抛出无效堆错误。
例如:
push_heap(v.begin(), v.end(), greater<int>());
vector 为755, 98, 55, 22
你会在 push_heap 之后看到:
22, 98, 55, 755
但假设你有 22、98、55、755
通常它会继续前进而不执行任何推送,因为比较时返回错误。这是意料之中的事。
但有时我会在以下位置尝试 push_heap:
887、52、44、22
它会说
'invalid heap'
或者如果我尝试: 22, 52, 44, 887,而不是仅仅返回 false 并继续前进,它会打破
'invalid heap'
有时 pop_heap 也会发生这种情况。
为什么我得到无效堆?是因为所有堆都必须按降序排列吗?
编辑:我在 cplusplus.com 上找到了这个,我猜它回答了一个问题:
具有最高值的元素总是第一个指向。其他元素的顺序取决于特定的实现,但在该 header 的所有与堆相关的函数中都是一致的。
最佳答案
... push_heap has two arguments and by default it pushes the least value to position last-1. It only does this if the first argument is less than the second argument, otherwise it stays the same.
没有。如果你的存储是 vector v
,并且当前是一个堆(使用 make_heap
创建),您应该调用
v.push_back(new_item);
push_heap(v.begin(), v.end());
考虑 push_heap
确实采用范围 [begin, end-1)
(已经需要满足堆不变性)和 end-1
处的附加元素(可能不会),并向上移动最后一个元素,直到为所有 [begin, end)
恢复堆不变量。 .算法解释here .
After finding that push_heap wasn't really keeping my vector sorted ...
堆没有排序。它们有一个排序约束 ( the heap property ),特别有意地弱于完全排序。
如果你想执行二进制搜索,你需要一个完全排序的容器,并使用 sort_heap
将你的堆转换为一个堆。每次都既缓慢又具有破坏性:调用此方法后,您的容器不再是堆,您不能将其用作一个。
现在,关于您的编辑:堆不必必须按降序排列。最大堆是降序(最大元素在前),最小堆是升序(最小元素在前)。
标准库中的默认是构建一个最小堆,使用operator<
进行比较。要改为构建最大堆,您只需传递 std::greater<int>
或任何(可选的)最终参数。
关于c++ - 堆问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15621207/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!