我正在实现队列数据结构,但是我的应用程序崩溃了。我知道队列类的Node指针front或Front()方法做错了
#include <iostream>
using namespace std;
class Node
{
public:
int get() { return object; };
void set(int object) { this->object = object; };
Node * getNext() { return nextNode; };
void setNext(Node * nextNode) { this->nextNode = nextNode; };
private:
int object;
Node * nextNode;
};
class queue{
private:
Node *rear;
Node *front;
public:
int dequeue()
{
int x = front->get();
Node* p = front;
front = front->getNext();
delete p;
return x;
}
void enqueue(int x)
{
Node* newNode = new Node();
newNode->set(x);
newNode->setNext(NULL);
rear->setNext(newNode);
rear = newNode;
}
int Front()
{
return front->get();
}
int isEmpty()
{
return ( front == NULL );
}
};
main()
{
queue q;
q.enqueue(2);
cout<<q.Front();
system("pause");
}
最佳答案
您多次使用未初始化的指针。
我的建议:
关于c++ - 使用front()方法使队列数据结构应用崩溃,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/13452320/