Evaluate integer expressions

Assignment Help Basic Computer Science
Reference no: EM13551406

Evaluate integer expressions. Your program need only implement the following binary operators:

+ ... addition
- ... subtraction
* ... multiplication
/ ... integer division
< ... minimum (e.g. 3 < 2 yields 2)
> ... maximum (e.g. 3 > 2 yields 3)

To keep the assignment somewhat more manageable you may assume that all input integers are unsigned single decimal digits (0-9). However, your evaluation may result in larger and/or negative integers.

The evaluation of expressions must recognize the standard precedence:
< and > have the highest precedence
* and / have the middle precedence
+ and - have lowest precedence

Expressions must also permit the usual use of parentheses (...) to override precedence. Below are several examples of proper expressions:

1+2*3>4

(24-7)/2+6<3*(31-299)

2*3*4*5*6

10>9*8+7+2

Your program must read input expressions from a text file and allow the user to select which text file to process using a JFileChooser. You may assume that each line of the text file is a separate integer expression and that there are no blanks or other invalid characters in the file.

For each input expression your program should output (using System.out.println) the input line followed by "==" then followed by the numeric value of the resulting expressions evaluation.

You must implement a generic Stack class like the one given in lecture.

The standard algorithm for evaluating expressions of this style is to use two stacks - one stack for operators (the operator stack) and the other for operands/subexpression values (the operand stack). An expression is processed left to right as follows:

• Each operand encountered is pushed upon the operand stack.

• Each left paren encountered is pushed upon the operator stack.

• Each right paren causes operators to be popped from the operator stack and the associated subexpressions evaluated until a left paren is found in the operator stack. The left paren is then popped.

• Each operator has its precedence compared to the precedence of the operator atop the operator stack. Operators are popped off the operator stack and their corresponding subexpressions evaluated until the top of the operator stack is either a left paren or has a precedence less than the new operator. After evaluating subexpressions, the new operator is pushed onto the operator stack.

• At the end of the expression all operators on the operator stack must be popped and their corresponding subexpressions evaluated. The value of the expression should be the single remaining value atop the operand stack.

When the prior explanations refer to "popping an operator and evaluating the corresponding subexpression" this means that the operand stack should be popped twice, and the two popped operands are evaluated using the popped operator with the resulting value pushed on the operand stack. For example, if the top of the operand stack is a 7 and the second operand in the operand stack is a 3 and the operator is a "-", then all three of these are popped and the result of the subexpression 3-7 (i.e., the value -4) is pushed on the operand stack.

Reference no: EM13551406

Questions Cloud

Campbell corporation uses baumol model to manage cash : Campbell Corporation uses Baumol model to manage cash.
What is the angle between the axes of the polarizers : Unpolarized light with an intensity of585W / m2 is incident on a polarizer with an unknown axis. The light then passes through a second polarizer with has an axis which makes an angle of67.0° with the vertical.
Explain the thermite reaction and the calculated : The thermite reaction combines aluminum powder and iron oxide and ignites the mixture to make aluminum oxide and iron. Use the heat capacities of the products and reactants of the thermite reaction and the calculated
The payment structure of a corporate bond : The payment structure of a corporate bond is best thought
Evaluate integer expressions : Evaluate integer expressions - evaluation of expressions must recognize the standard precedence
What are the wavelength of the second overtone : A 2.00 m long rope is stretched between two supports with a tension that makes the speed of transverse waves 48.0 m/s. What are the wavelength of the second overtone
Find out the entropy of mixing for 1 mole of such a mixture : Dentists might use a mixture of 40% N2O and 60% O2 as an initial anesthetic of nitrous oxide(although exact proprtions may vary). Determine the entropy of mixing for 1 mole of such a mixture. Assume ideal gas conditions.
What light intensity emerges from the third filter : Unpolarized light of intensityI0is incident on three polarizing filters. The axis of the first is vertical, that of the second is29° from vertical, and that of the third is horizontal. What light intensity emerges from the third filter?
What is the common-size percentage for inventory account : Tom's Hardware has inventory of $318,000, equity of $421,800, total assets of $647,700, and sales of $687,400. What is the common-size percentage for the inventory account?

Reviews

Write a Review

Basic Computer Science Questions & Answers

  Design a ram chip

Design a RAM chip that is 128K x 8. For each sub-part below, show the array of RAM cells and its dimensions, the decoder(s) required to access the array, and tabulate the numbers of gates required to implement the decoding.

  A consistent pattern or does it have peaks and valleys

How many requests from users does ESPN receive each second? Do you think this is a consistent pattern or does it have peaks and valleys? When does it peak?

  How much cpu time each user process has had recently

Modify the MINIX 3 scheduler to keep track of how much CPU time each user process has had recently. When no task or server wants to run, pick the user process that has had the smallest share of the CPU.

  Explain the four stages of the bpm process and summarize

Explain the four stages of the BPM process and summarize the activities in each.

  What are some possible problems that could still exist

A user complains to you that her system hangs for no known reason. After asking her a few questions, you do identify these symptoms: The system hangs after about 15-20 minutes of operation.

  Research about yahtzee

Previously you conducted research about Yahtzee. Hopefully you gained valuable information on the game, scoring, and the outcomes. Now, let's work on creating our dice and our number generator.

  Identify the equivalence classes

Identify the equivalence classes

  Describe the types of information available to a program

Describe the types of information available to a program when using the KeyListener interface.

  Strategic advantages voip brings to businesses

Write down some of the strategic advantages the VoIP brings to businesses that adopt it? Prior, voice and data networks were separate and typically maintained by separate groups.

  Assess and evaluate key aspects of legal

Identify ethical, social and legal issues relevant to Information Systems within a context of application and assess and evaluate key aspects of legal, ethical and cultural issues relevant to an IT professional

  Display a message for asking your first name

Display a message for asking your first name, and then use your first and last names display a greeting message, e.g. "Hello, John Smith!".

  Write a php script that computes the total cost

Write a PHP script that computes the total cost of the ordered light bulbs from above after adding 6.2 percent sales tax. The program must inform the buyer of exactly what was ordered, in a table.

Free Assignment Quote

Assured A++ Grade

Get guaranteed satisfaction & time on delivery in every assignment order you paid with us! We ensure premium quality solution document along with free turntin report!

All rights reserved! Copyrights ©2019-2020 ExpertsMind IT Educational Pvt Ltd