- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 C++ 的新手,正在制作用 C++ 编写的哈夫曼树,但在生成树结构时遇到了麻烦。
这是我的代码:
void Huffman::generateTree() {
std::vector<Node> nodes;
for (auto itr : freq) {
nodes.push_back(*(new Node(itr.first, itr.second)));
}
while (nodes.size() > 1) {
Node::sort(&nodes);
Node leftNode = nodes.back();
nodes.pop_back();
Node rightNode = nodes.back();
nodes.pop_back();
Node newAnode = *new Node();
newAnode.merge(&leftNode,&rightNode);
nodes.push_back(newAnode);
}
root = &nodes.back();
displayTree();
}
最终合并为一个节点,但是左节点和右节点是错误的:
NODE freq26|id96
|-Left:
NODE freq10|id17
|-Left:
|--ERROR:SELF freq10|id17
|-Right:
NODE freq16|id19
|-Left:
NODE freq10|id17
|-Left:
|--ERROR:SELF freq10|id17
|-Right:
NODE freq16|id19
|-Left:
NODE freq10|id17
|-Left:
|--ERROR:SELF freq10|id17
|-Right:
NODE freq16|id19
...endless loop
就像输出一样,从第一个子节点开始,每个节点的左子节点都是它自己,右节点是另一个节点,但只有两个相互切换,最后循环。
pop_back
引起的。和
push_back
元素到 vector ,指针可能指向另一个元素,但我该如何解决呢?有没有办法在不受操作 vector 影响的 vector 中获取REAL元素?
//header
class Node {
private:
char value;
int frequency;
Node *left;
Node *right;
String code;
...
class Huffman{
private:
Node * root;
std::map<char,int> freq;// calculated frequency of data
bool generated;
//source
bool Node::sortMethod::operator()(const Node &nodeA, const Node &nodeB) {
return nodeA.getFrequency() > nodeB.getFrequency();//getFrequency(): simply return node's frequency int
}
void Node::sort(std::vector<Node> *nodes) {
std::sort(nodes->begin(), nodes->end(), sortMethod());
}
Node *Node::merge(Node *pLeft, Node *pRight) {
left = pLeft;
right = pRight;
frequency = left->getFrequency() + right->getFrequency();
return this;
}
欢迎一切有帮助的,谢谢!
最佳答案
正如评论所暗示的那样,您需要停止认为 C++ 与 Java 相似,实际上并非如此。
C++ 中的对象具有明确的生命周期,并且该语言不会阻止您在对象不再存在后保留引用或指向对象的指针。
如果您希望某些东西比创建它的调用生命周期更长,则需要动态分配它,并且某些东西应该跟踪它的生命周期。默认为 std::unique_ptr
,当指针被销毁时,它会删除它所指向的内容。您可以通过移动 unique_ptr
来转让所有权。 .
不幸的是,您不能有效地拥有 std::priority_queue
的 std::unique_ptr
因为你不能移动 top
, 和 pop
不返回值。否则我会建议使用它而不是重新实现它。
我认为您不必在每个循环中对节点进行排序,因为合并的节点将始终具有最大的 frequency
,所以他们走在后面。
class Node;
// Aliases for types we will use
using NodePtr = std::unique_ptr<Node>;
using Nodes = std::vector<NodePtr>;
class Node {
private:
char value;
int frequency;
NodePtr left;
NodePtr right;
std::string code;
Node(char value, int frequency) : value(value), frequency(frequency) /*, code?*/{}
Node(NodePtr left, NodePtr right) : /*value? ,*/ frequency(left->frequency + right->frequency), left(std::move(left)), right(std::move(right)) /*, code?*/{}
...
};
// N.b. not members of Node
bool compareNodePtrs(const NodePtr & left, const NodePtr & right) {
return left->getFrequency() > right->getFrequency();
}
void sortNodes(Nodes & nodes) {
std::sort(nodes.begin(), nodes.end(), compareNodePtrs);
}
void Huffman::generateTree() {
Nodes nodes;
for (auto itr : freq) {
nodes.emplace_back(std::make_unique<Node>(itr.first, itr.second));
}
sortNodes(nodes);
while (nodes.size() > 1) {
auto left = std::move(nodes.back());
nodes.pop_back();
auto right = std::move(nodes.back());
nodes.pop_back();
nodes.emplace_back(std::move(left), std::move(right));
}
root = std::move(nodes.back());
displayTree();
}
关于c++ - CPP :How to get the REAL element in a vector?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67883076/
#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
我是一名优秀的程序员,十分优秀!