-1

编辑 2:程序现在正在运行。感谢您的帮助 最后一个问题:每次推送时我都会为 top 分配内存。如果我想在 pop 中删除它,这段代码会起作用吗?

int pop()
{
cout << "About to pop: " << top->getData() << "\n";
  int retVal = top->getData();
  if(top->getLasty()!=NULL)
 {
  node* temp = top;
  top = top->getLasty();
  delete temp;
  cout << "new data is: " << top->getData() << "\n";
 }
return retVal;
}
};

工作代码:

#include <iostream>
using namespace std;

class node
{
  int data;
  node* lasty;

  public:
  node()
  {
   lasty = NULL;
   data = -1;
  }
  node(node* ptr,int dat)
    {
    lasty = ptr;
    data = dat;
    cout << "New node created! Data is " << dat << ", lasty's data is " << ptr->getData() << "\n";
    }
   node* getLasty()
   {
    return lasty;
   }
   int getData()
   {
     return data;
   }
   void setData(int x)
   {
    data = x;
   }

   void setLasty(node* ptr)
   {
    lasty = ptr;
   }
};

class stack
{
node* top;

public:
stack()
{
 cout << "New Stack created!\n";
 top = new node();
}
~stack()
{
delete top;
}

void push(int x)
{
cout << "Before pushing, top's data is " << top->getData() << "\n";
top = new node(top, x);
//node* temp = new node();
//temp->setData(x);
//temp->setLasty(top);
//top = temp;
cout << "TOP'S DATA IS: " << top->getData() << "\n";
cout << "TOP: " << "top lasty's data is: " << top->getLasty()->getData() << "\n\n";
}

int pop()
{
cout << "About to pop: " << top->getData() << "\n";
  int retVal = top->getData();
  if(top->getLasty()!=NULL)
 {
  top = top->getLasty();
  cout << "new data is: " << top->getData() << "\n";
 }
return retVal;
}
};

int main()
{
stack a;
 a.push(1);
 a.push(2);
 a.push(3);
 cout << a.pop();
 cout << a.pop();
    return 0;
}

事实证明我需要更多文本来提交此编辑,因此请考虑使用此填充文本。

4

2 回答 2

1
stack()
{
 cout << "New Stack created!\n";
 node a = node();
 top = &a;
}

Nodea是局部变量,因此在传递构造函数的主体后被销毁。然后指针指向top被破坏的对象。您应该在堆中创建它并稍后将其删除。

stack()
{
 cout << "New Stack created!\n";
 top = new Node();
}
于 2013-06-02T16:44:10.830 回答
0

另一个问题:

node(node ptr,int dat)
{

    lasty = &ptr;
    data = dat;
    cout << "New node created! Data is " << dat << ", lasty's data is " << ptr.getData() << "\n";
}

您正在获取复制变量的地址。当ptr通过时,编译器正在制作原始项目的副本。这称为按值传递。

由于变量的名称是ptr,我假设您正在传递一个指向节点的指针。您应该分配指针的值,而不是其地址:

// Original
// lasty = &ptr;

// Assigning the pointer value:
lasty = ptr;
// Notice removal of `&`.

您可以将指针分配给指针。

于 2013-06-02T17:27:03.160 回答