0

我需要一些帮助:我被要求对 2 个堆栈的比较运算符进行一些重载。我已经弄清楚了语法,我只是在编写定义时遇到了麻烦。所以请帮助我。

至少一个运算符重载,然后我会为其余的。

struct linklist
{
    int no;
    struct linklist *next;
};

class Stack
{
private:
    linklist *list,*head;

public://constructor and destructor
    Stack();
    ~Stack();
public:// main functions
    void push();
    void show();
    void pop();

public://overloaded operations

    friend bool operator == (const Stack &stack1, const Stack &stack2);
    friend bool operator != (const Stack &stack1, const Stack &stack2);
    friend bool operator < (const Stack &stack1, const Stack &stack2);
    friend bool operator > (const Stack &stack1, const Stack &stack2);

};
4

1 回答 1

1

这实际上取决于您实际想要比较的内容。是堆栈的标识还是堆栈上的元素数量?由于您要定义越来越小的运算符,因此我假设您要比较堆栈中的元素数量。

等号运算符是这样的:

bool operator==( const Stack &stack1, const Stack &stack2)
{
  return stack1.list->no == stack2.list->no;
}

当然,您需要考虑 Stack 对象的列表成员为 NULL 的情况。

于 2013-10-24T20:46:06.260 回答