到目前为止我的代码是......
struct stack_struct
{
int number;
struct stack_struct *next_number;
};
stack_struct *mainStruct;
class stack_class
{
private:
struct stack_struct *head;
public:
stack_class();
~stack_class();
void pushNumber(int number);
void popNumber();
void findNumber();
void clearStack();
void sizeFinder();
void printStack();
void reverseStack();//Extra Credit
};
stack_class mainClassStack;
stack_struct *pointerFunc,*tailPointer=NULL,*pointerFunc3,*printPointer;
stack_class::stack_class()
{
head=NULL;
}
stack_class::~stack_class()
{
clearStack();
cout<<"\nList Cleared.\n";
system("pause");
}
void stack_class::popNumber()
{
stack_struct *pointerPop=NULL,*pointerPop2=NULL;
int popCounter=0,i=0;
pointerPop2=tailPointer;
if(head==NULL)
{
cout<<"\nNo Member to Delete.\n";
}
else
{
while(pointerPop2)
{
popCounter++;
//cout<<pointerFunc3->number<<endl;
pointerPop2=pointerPop2->next_number;
}
pointerPop=tailPointer;
while(i<(popCounter-2))
{
pointerPop=pointerPop->next_number;
i++;
}
pointerPop->next_number=NULL;
delete head;
head=pointerPop;
}
}
void stack_class::printStack()
{
pointerFunc3=tailPointer;
if(tailPointer==NULL)
{
cout<<"\nNo Members in List.\n";
}
else
{
cout<<"\n\nList Is:\n";
while(pointerFunc3)
{
cout<<pointerFunc3->number<<endl;
pointerFunc3=pointerFunc3->next_number;
}
}
}
只要不是最后一个数字,弹出就可以正常工作。如果弹出最后一个数字(列表为空),并且我尝试打印列表,程序将无限地打印垃圾。如果我在列表为空后尝试弹出一个数字,程序会冻结。我该如何解决这些问题?
答案 0 :(得分:0)
像这样改变你的popNumber(),
void stack_class::popNumber()
{
stack_struct *pointerPop=NULL,*pointerPop2=NULL;
int popCounter=0,i=0;
pointerPop2=tailPointer;
if(head==NULL)
{
cout<<"\nNo Member to Delete.\n";
}
else if(head->next_number==NULL)
{
cout<<"\nThe Poped element is"<<head->number;
head=NULL;
}
else
{
// Your Code;
}
}
答案 1 :(得分:0)
你也可以创建一个虚拟节点来解决这个问题。否则:
int stack_class::popNumber()
{
if(head==NULL)
throw new Exception("Stack is empty");
int result = head->number;
delete head;
head = head->next_number;
return result;
}
void stack_class::pushNumber(int number)
{
stack_struct *elem= new stack_struct();
elem->number = number;
elem->next_number = head;
head = elem;
}
int stack_class::popNumber()
{
if(head==NULL)
throw new Exception("Stack is empty");
int result = head->number;
delete head;
head = head->next_number;
return result;
}
void stack_class::pushNumber(int number)
{
stack_struct *elem= new stack_struct();
elem->number = number;
elem->next_number = head;
head = elem;
}
!!!!!尽量不要使用全局变量(stack_class mainClassStack;
stack_struct * pointerFunc,* tailPointer = NULL,)
答案 2 :(得分:0)
包括退出的cstdlib
int Stack::pop()
{ if (top == NULL)
{
cerr <<"Stack is empty";
exit(1);
}
else
{
Node* zap = top;
top = zap->link;
int return_value = zap->n;
delete zap;
return return_value;
}
}
Qazi你必须在两个程序的开头都进行if(top==NULL)
检查。