- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在用 C++ 实现二叉搜索树我有以下代码来向树中添加一个条目:
void tree::add(int n)
{
int found;
leaf *t,*parent;
findparent(n,found,parent);
if(found==YES)
cout<<"\nSuch a Node Exists";
else
{
t=new leaf;
t->data=n;
t->l=NULL;
t->r=NULL;
if(parent==NULL)
p=t;
else
parent->data > n ? parent->l=t : parent->r=t;
}
}
在我的主要任务中,我使用映射将从文本文件中读取的值存储为整数。现在,当我将值传递给 add 函数时,它会使程序崩溃。
int main()
{
tree t;
map<int,int> word;
map<int,int>::iterator count;
string str;
int num;
string space ="";
while((str=value(cin))!=space )
{
num = atoi(str.c_str());
++word[num];
}
int size = (int) word.size();
int data[size];
int x = 0;
for(count = word.begin(); count!=word.end(); ++count){
data[x] = (*count).first;
x = x+1;
}
for (int iter = 0; iter<size; iter++){
int x = 3 * data[iter];
t.add(x);
}
return 0;
}
我在这里所做的是,我使用 atoi 将用户输入转换为整数,然后将它们添加到 map 中。然后我得到 map 的大小并用它来用元素填充一个数组。现在,当我遍历数组并尝试使用 add 函数将数组元素传递给树时,它会使程序崩溃。当我尝试添加固定数组元素时,该程序运行良好。例如:
整数数据[] = {6,7,8,9};
如果我在我的 main 中有这个固定数组并传递要添加的元素,它工作正常,这让我觉得 add 方法没有问题。请帮我找到问题所在,我很困惑
整个程序的 Pastebin 链接:http://pastebin.com/SWqTccJf
最佳答案
我认为 Tyler Hyndman 是正确的,它不是标准的 C++。但是,例如 g++ 确实支持这种 C99 风格的“语言扩展”。它并没有消除这样一个事实,即在堆栈上分配大小在编译时未知的数组通常是一种不好的做法,而且实际上可能非常大。
我的猜测是代码中存在一个尚未提供的错误。一些涉及内存/指针问题的 bug 可以根据内存的内容被掩盖,这会让他们感到沮丧。无论如何,我在提供的代码中没有看到错误。我会注意它崩溃的确切位置,以及崩溃时程序的状态。
为获得最佳帮助,请提供最少(但足够)的代码来重现问题。如果看起来太多,也许可以使用 pastebin?
//EDIT// 好的,我查看了您的完整代码 list 。
查看此 revised code .主要区别:
1) 您在清除树的代码中存在错误。不应在此处调用 Tree::del(),因为它用于删除特定值。它必须找到要删除的节点,然后处理各种特殊情况。当您清除树的内容时,您可以继续递归地删除所有节点。简单快捷!
2) 我将你的两个查找功能合并为一个。
3) Tree::del 中存在错误,因为被删除的节点是根节点。当删除根节点时,parent 将为 NULL...
4) 从输入中读取数字的逻辑已更改。
我希望您能研究代码并查看更改内容和原因。还要记住准确查看代码崩溃的位置并获取尽可能多的有关崩溃的信息,而不是仅仅说“天啊,它崩溃了!”。
最好的问候:)
关于c++ - 二叉搜索树崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8190938/
#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
我是一名优秀的程序员,十分优秀!