home *** CD-ROM | disk | FTP | other *** search
/ Chip 2002 May / Chip_2002-05_cd1.bin / chplus / cpp / 3 / stl.exe / calc.cpp < prev    next >
C/C++ Source or Header  |  1998-02-09  |  4KB  |  122 lines

  1. #include "stlexam.h"
  2. #pragma hdrstop
  3. /**************************************************************************
  4.  *
  5.  * calc.cpp - RPN Calculator -- Illustration of the use of stacks.
  6.  *      Section 10.2.1
  7.  *
  8.  * $Id: calc.cpp,v 1.13 1996/09/03 22:26:40 smithey Exp $
  9.  *
  10.  ***************************************************************************
  11.  *
  12.  * (c) Copyright 1994, 1995 Rogue Wave Software, Inc.
  13.  * ALL RIGHTS RESERVED *
  14.  * The software and information contained herein are proprietary to, and
  15.  * comprise valuable trade secrets of, Rogue Wave Software, Inc., which
  16.  * intends to preserve as trade secrets such software and information.
  17.  * This software is furnished pursuant to a written license agreement and
  18.  * may be used, copied, transmitted, and stored only in accordance with
  19.  * the terms of such license and with the inclusion of the above copyright
  20.  * notice.  This software and information or any other copies thereof may
  21.  * not be provided or otherwise made available to any other person.
  22.  *
  23.  * Notwithstanding any other lease or license that may pertain to, or
  24.  * accompany the delivery of, this computer software and information, the
  25.  * rights of the Government regarding its use, reproduction and disclosure
  26.  * are as set forth in Section 52.227-19 of the FARS Computer
  27.  * Software-Restricted Rights clause.
  28.  * 
  29.  * Use, duplication, or disclosure by the Government is subject to
  30.  * restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in
  31.  * Technical Data and Computer Software clause at DFARS 252.227-7013.
  32.  * Contractor/Manufacturer is Rogue Wave Software, Inc.,
  33.  * P.O. Box 2328, Corvallis, Oregon 97339.
  34.  *
  35.  * This computer software and information is distributed with "restricted
  36.  * rights."  Use, duplication or disclosure is subject to restrictions as
  37.  * set forth in NASA FAR SUP 18-52.227-79 (April 1985) "Commercial
  38.  * Computer Software-Restricted Rights (April 1985)."  If the Clause at
  39.  * 18-52.227-74 "Rights in Data General" is specified in the contract,
  40.  * then the "Alternate III" clause applies.
  41.  *
  42.  **************************************************************************/
  43.  
  44.  
  45. #ifndef _RWSTD_HEADER_REQUIRES_HPP
  46. #include <vector>
  47. #include <stack>
  48. #else
  49. #include <vector.hpp>
  50. #include <stack.hpp>
  51. #endif
  52.  
  53. #ifdef _RW_STD_IOSTREAM
  54. #include <iostream>
  55. #else
  56. #include <iostream.h>
  57. #endif
  58.     
  59. #ifndef _RWSTD_NO_NAMESPACE
  60.   using namespace std;
  61. #endif
  62.  
  63. //
  64. // Simulate the behavior of a simple integer calculator.
  65. //
  66.  
  67. class CalculatorEngine
  68. {
  69.   public:
  70.     enum binaryOperator { PLUS, MINUS, TIMES, DIVIDE };
  71.     int  currentMemory ()                { return data.top(); }
  72.     void pushOperand   (int value)       { data.push (value); }
  73.     void doOperator    (binaryOperator);
  74.   protected:
  75.     stack< int, vector<int,allocator<int> > > data;
  76. };
  77.  
  78. void CalculatorEngine::doOperator (binaryOperator theOp)
  79. {
  80.     int right = data.top();
  81.     data.pop();
  82.     int left = data.top();
  83.     data.pop();
  84.     switch (theOp)
  85.     {
  86.         case PLUS:   data.push(left + right); break;
  87.         case MINUS:  data.push(left - right); break;
  88.         case TIMES:  data.push(left * right); break;
  89.         case DIVIDE: data.push(left / right); break;
  90.     }
  91. }
  92.  
  93. int main()
  94. {
  95.     cout << "Calculator example program, from Chapter 8" << endl;
  96.  
  97.     cout << "Enter a legal RPN expression, end with p q (print and quit)" << endl;
  98.     int intval;
  99.     CalculatorEngine calc;
  100.     char c;
  101.     
  102.     while (cin >> c)
  103.         switch (c)
  104.         {
  105.             case '0': case '1': case '2': case '3': case '4':
  106.             case '5': case '6': case '7': case '8': case '9':
  107.                 cin.putback(c);
  108.                 cin >> intval;
  109.                 calc.pushOperand(intval);
  110.                 break;
  111.             case '+': 
  112.                 calc.doOperator(CalculatorEngine::PLUS); break;
  113.             case '-': calc.doOperator(CalculatorEngine::MINUS); break;
  114.             case '*': calc.doOperator(CalculatorEngine::TIMES); break;
  115.             case '/': calc.doOperator(CalculatorEngine::DIVIDE); break;
  116.             case 'p': cout << calc.currentMemory() << endl;
  117.             case 'q': cout << "End calculator program" << endl;
  118.                 return 0; // quit program
  119.         }
  120.     return 0;
  121. }
  122.