CMSC350 Program that accepts an arithmetic expression

Question # 00652610
Subject: Computer Science
Due on: 03/06/2024
Posted On: 03/06/2024 04:09 AM
Tutorials: 1
Rating:
4.9/5
Question Dot Image

CMSC350 Program that accepts an arithmetic expression

The second programming project involves writing a program that accepts an arithmetic expression of unsigned integers in postfix notation and builds the arithmetic expression tree that represents that expression. From that tree, the corresponding fully parenthesized infix expression should be displayed and a file should be generated that contains the three address format instructions. This topic is discussed in the week 4 reading in module 2, section II-B. The main class should create the GUI shown below:

The GUI must be generated by code that you write. You may not use a drag-and-drop GUI generator.

Pressing the Construct Tree button should cause the tree to be constructed and using that tree, the corresponding infix expression should be displayed and the three address instruction file should be generated.

The postfix expression input should not be required to have spaces between every token. Note in the above example that 9+- are not separated by spaces.

The above example should produce the following output file containing the three address instructions:

Add R0 5 9
Sub R1 3 R0
Mul R2 2 3
Div R3 R1 R2

It is not necessary to reuse registers within an expression as shown in module 2, section II-B, and you can assume there are as many available as needed. Each new expression should, however, begin using registers starting at R0.

Inheritance should be used to define the arithmetic expression tree. At a minimum, it should involve three classes: an abstract class for the tree nodes and two derived classes, one for operand nodes and another for operator nodes. Other classes should be included as needed to accomplish good object-oriented design. All instance data must be declared as private.

You may assume that the expression is syntactically correct with regard to the order of operators and operands, but you should check for invalid tokens, such as characters that are not valid operators or operands such as 2a, which are not valid integers. If an invalid token is detected a

1

RuntimeException should be thrown and caught by the main class and an appropriate error message should be displayed. Below is an example:

You are to submit two files.

  1. The first is a .zip file that contains all the source code for the project, which includes any code that was provided. The .zip file should contain only source code and nothing else, which means only the .java files. If you elect to use a package the .java files should be in a folder whose name is the package name.
  2. The second is a Word document (PDF or RTF is also acceptable) that contains the documentation for the project, which should include the following:
    1. A UML class diagram that includes all classes you wrote. Do not include predefined classes. You need only include the class name for each individual class, not the variables or methods
    2. A test plan that includes test cases that you have created indicating what aspects of the program each one is testing
    3. A short paragraph on lessons learned from the project
Dot Image
Getsolution Posted By :
Questions: 14841 Tutorials: 14840
Tutorials for this Question

CMSC350 Program that accepts an arithmetic expression

Tutorial # 00651509
Posted On: 03/06/2024 04:10 AM
Feedback Score: Not rated yet!
Purchased By: 2
Getsolution
Posted By:
Questions:
14841
Tutorials:
14840
Report this Tutorial as Inappropriate
Tutorial Preview
The solution of CMSC350 Program that accepts an arithmetic expression...
Attachments
CMSC350_Program_that_accepts_an_arithmetic_expression.ZIP (18.96 KB)

Great! We have found the solution of this question!

Related Questions
Examine the several different types of data insights that occur
Question Examine the several different types of data insights that occur in big data analytics:  ? Offer novel knowledge  ? Provide causation relationships  ? Add a competit …
Computer science - Is virtualisation cost effective
Computer science question Is virtualisation cost effective and does it support green IT? Contents Introduction Is Virtualisation cost effective? Running out of space? Needing Virtualisa …
Studying Computing involves developing both subject
Studying Computing involves developing both subject-specific and transferable skills. Describe the skills you have used prior to university, and discuss how you would expect those skills to develop wh …
Computer Science - Discuss the critical characteristics
Computer Science Question Assignment 1 - Question 1: Discuss the critical characteristics of communication channels in data communications. Explain how bandwidth and communication medium affe …
List and explain two browser add-ons(plug-ins)that improve the security
1- List and explain two browser add-ons(plug-ins)that improve the security of a user’s browser. Why are these features not built-into the browser? 2- What are two security risks associated wi …
How are browsers being used to mine crypto currency
Part A: How are browsers being used to mine crypto currency? (1 pt) Find an example of malvertising. Provide a screen shot of the malvertising. (2 pts) Provide the details on how and where you …
What are the seven categories of cybersecurity functions in the NICE
security awareness What are the seven categories of cybersecurity functions in the NICE Cybersecurity Workforce Framework (https://www.nist.gov/itl/applied-cybersecurity/nice/resources/nice-cybe …
The Computer Mouse - Once a nondescript box perched on a large
The Computer Mouse Once a nondescript box perched on a large ball bearing, today the computer mouse comes in a wide range of shapes with a variety of capabilities. There are cordless mice, ergonomi …
CMSC350 Program that accepts an arithmetic expression
CMSC350 Program that accepts an arithmetic expression The second programming project involves writing a program that accepts an arithmetic expression of unsigned integers in postfix notation and bu …
Week 6 Discussions - Local Security Good Practices
Week 6 Discussions Please respond to at least two main topics  1. Local Security Good Practices Discuss in detail several effective local security practices to harden your Linux distribu …
Recent Questions
How do people learn in later years and what type of educational
How do people learn in later years and what type of educational activities can be offered to aging individuals? In this assignment, you will write a brief article suitable for use in a fictional onlin …
Counselling Deaf Clients in Canada - Socio-cultural and demographic
Counselling Deaf Clients in Canada. A. Socio-cultural and demographic background - In this section, include descriptive information about the specific cultural group that you have researched, such …
Project One Planning Document First Draft
Project One Planning Document First Draft Overview You have identified an issue in the natural sciences and developed an  initial research question. In Modules Three and Four, you will prac …
Psychology - Describe the schema you might form about
Psychology Question Assignment #1: Schemas. Visit www.amazon.com and find a product that is of interest to you. Read two conflicting reviews for the product. 1) Describe the schema you might for …
PSYC450 Family Systems Theoretical Analysis
PSYC 450 Family Systems Theoretical Analysis Create a 12-15 narrated presentation about Theoretical Analysis in family systems. Each slide requires 1-2 minutes of voice narration. You have to add A …
HUS320 Final Project: Crisis Intervention Plan and Reflection
HUS 320: Final Project: Crisis Intervention Plan and Reflection Learning Objectives: Design Comprehensive Crisis Plans Task: Imagine a complex crisis scenario (for example, a community affected by …
Psychology - One of the more controversial issues
Psychology Central Texas College One of the more controversial issues in the study of psychology has been the mind-body problem. Consequently, scholars have argued for a very long time about how th …
Psychology - Ethical Appropiateness, Do you believe testing
Psychology: Ethical Appropiateness Respond to the following  1. Do you believe testing can be conducted in a fair and unbiased manner? Why or why not? 2. What are factors that need to be c …
Personality Theories in the Psychodynamic Tradition
Personality Theories in the Psychodynamic Tradition [ Before beginning work on this discussion, read the chapter in your textbook that coincides with your assigned theorist (below). In addition, re …
Psychology - Summarize the key assumptions and assertions
Psychology Question This assignment is intended to prompt you to examine the ways in which gender-based attitudes and beliefs affect support for specific social policies. You will continue to exami …