stackt.h

来自「Think in C++ 第二版源码」· C头文件 代码 · 共 45 行

H
45
字号
//: C16:Stackt.h

// From Thinking in C++, 2nd Edition

// Available at http://www.BruceEckel.com

// (c) Bruce Eckel 1999

// Copyright notice in Copyright.txt

// Simple stack template

#ifndef STACKT_H

#define STACKT_H

template<class T> class StacktIter; // Declare



template<class T>

class Stackt {

  static const int ssize = 100;

  T stack[ssize];

  int top;

public:

  Stackt() : top(0) { stack[top] = 0; }

  void push(const T& i) {

    if(top < ssize) stack[top++] = i;

  }

  T pop() {

    return stack[top > 0 ? --top : top];

  }

  friend class StacktIter<T>;

};



template<class T>

class StacktIter {

  Stackt<T>& s;

  int index;

public:

  StacktIter(Stackt<T>& is)

    : s(is), index(0) {}

  T& operator++() { // Prefix form

    if (index < s.top - 1) index++;

    return s.stack[index];

  }

  T& operator++(int) { // Postfix form

    int returnIndex = index;

    if (index < s.top - 1) index++;

    return s.stack[returnIndex];

  }

};

#endif // STACKT_H ///:~

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?