Programming Language Pragmatics, Fourth Edition
Programming Language Pragmatics, Fourth Edition
4th Edition
ISBN: 9780124104099
Author: Michael L. Scott
Publisher: Elsevier Science
Expert Solution & Answer
Book Icon
Chapter 3, Problem 21E

Explanation of Solution

Code which supports unary negation and the four standard arithmetic operators:

//include the required header files

#include <cmath>

using std::abs;

using std::round;

#include <iostream>

using std::ostream;

using std::cout;

//definition of class "rational"

class rational

{

    //declare the required variables

    int num;

    int den;

    //definition of "gcd" function

    int gcd(int i, int j)

    {

        //set the absolute values

        i = abs(i);

        j = abs(j);

        //check "i" is not equal to "j"

        while (i != j)

        {

            //check "i" is greater than "j"

            if (i > j)

/*subtract the values and store the result in "i"*/

                i = i - j;

            //otherwise

            else

/*subtract the values and store the result in "j"*/

            j = j - i;

        }

        //return the "i" value

        return i;

    }

    //definition of "normalize" function

    void normalize()

    {

        //check "den" is less than 0

        if (den < 0)

        {

            //calculate numerator value

            num = -num;

            //calculate denominator value

            den = -den;

        }

        //call the "gcd" function with a parameters

        int g = gcd(num, den);

        //calculate numerator value

        num /= g;

        //calculate denominator value

        den /= g;

    }

    //access specifier

    public:

    //definition constructor

    rational(int n, int d)

    {

        //set the values

        num = n;

        den = d;

        //call the function

        normalize();

    }

    // definition of constructor

    rational(double r, double e)

    {

        //set the values

        num = (int) r;

        den = 1;

        //check the condition

while (abs(r - ((double)num)/((double)den)) > e)

        {

            //increment the value

            ++den;

            //calculate numerator value

            num = round(den*r);

        }

    }

    //definition of operator "-"

    rational operator-()

    {

        //calculate numerator value

        num = -num;

        //return the value

        return *this;

    }

    //definition of operator "+"

    rational operator+(const rational o)

    {

        //declare the variable and calculate the value

        int p = den * o.den;

        //calculate numerator value

        num = num * o.den + den * o.num;

        //set the value

        den = p;

        //call the function

        normalize();

        //return the value

        return *this;

    }

    //definition of operator "-"

    rational operator-(const rational o)

    {

        //declare the variable and calculate the value

        int p = den * o.den;

        //calculate numerator value

        num = num * o.den - den * o.num;

        //set the value

        den = p;

        //call the function

        normalize();

        //return the value

        return *this;

    }

    //definition of operator "*"

    rational operator*(const rational o)

    {

        //calculate numerator value

        num *= o.num;

        //calculate denominator value

        den *= o.den;

        //call the function

        normalize();

        //return the value

        return *this;

    }

    //definition of operator "/"

    rational operator/(const rational o)

    {

        //calculate numerator value

        num *= o.den;

        //calculate denominator value

        den *= o.num;

        //call the function

        normalize();

        //return the value

        return *this;

    }

};

Explanation:

  • The header files are included in the beginning of the program.
  • The “rational” class is defined. Inside the class,
    • The “num” and “den” variables are declared.
    • The “gcd” function is defined
      • Get the absolute values of “i” and “j” and store it in the corresponding variables.
      • The “while” loop is used to check “i” is not equal to “j”.
        • If the “i” value is greater than “j” value, then subtract the “i” and “j” value and store the result in the “i” variable.
        • Otherwise, subtract the “j” and “i” value and store the result in the “j” variable.
      • Return the “i” value.
    • The “normalize” function is defined.
      • If the “den” is less than 0, then calculate the “num” and “den” values.
      • Call the “gcd” function with the parameters.
      • Calculate the numerator and denominator values.
    • The constructor of “rational” is defined with two parameters.
      • Set the values
      • Call the “normalize” function.
    • Again, the constructor of “rational” is defined with another two parameters.
      • Set the values.
      • Check the “while” condition
        • Increment the denominator value
        • Calculate the numerator
    • The operator “-” is defined
      • Calculate the “num” value
      • Return the result
    • The operator “+” is defined with parameter
      • Calculate the “p” and “num” values
      • Set the value
      • Call the “normalize” function
      • Return the result
    • The operator “-” is defined with parameter
      • Calculate the “p” and “num” values
      • Set the value
      • Call the “normalize” function
      • Return the result
    • The operator “*” is defined with parameter
      • Calculate the “den” and “num” values
      • Call the “normalize” function
      • Return the result
    • The operator “/” is defined with parameter
      • Calculate the “den” and “num” values
      • Call the “normalize” function
      • Return the result

Want to see more full solutions like this?

Subscribe now to access step-by-step solutions to millions of textbook problems written by subject matter experts!
Students have asked these similar questions
Task 2: Comparable Interface and Record (10 Points) 1. You are tasked with creating a Java record of Dog (UML is shown below). The dog record should include the dog's name, breed, age, and weight. You are required to implement the Comparable interface for the Dog record so that you can sort the records based on the dogs' ages. Create a Java record named Dog.java. name: String breed: String age: int weight: double + toString(): String > Dog + compareTo(otherDog: Dog): int > Comparable 2. In the Dog record, establish a main method and proceed to generate an array named dogList containing three Dog objects, each with the following attributes: Dog1: name: "Buddy", breed: "Labrador Retriever", age: 5, weight: 25.5 Dog2: name: "Max", breed: "Golden Retriever", age: 3, weight: 30 Dog3: name: "Charlie", breed: "German Shepherd", age: 2, weight: 22 3. Print the dogs in dogList before sorting the dogList by age. (Please check the example output for the format). • 4. Sort the dogList using…
The OSI (Open Systems Interconnection) model is a conceptual framework that standardises the functions of a telecommunication or computing system into seven distinct layers, facilitating communication and interoperability between diverse network protocols and technologies. Discuss the OSI model's physical layer specifications when designing the physical network infrastructure for a new office.
In a network, information about how to reach other IP networks or hosts is stored in a device's routing table. Each entry in the routing table provides a specific path to a destination, enabling the router to forward data efficiently across the network. The routing table contains key parameters determining the available routes and how traffic is directed toward its destination. Briefly explain the main parameters that define a routing entry.
Knowledge Booster
Background pattern image
Similar questions
SEE MORE QUESTIONS
Recommended textbooks for you
Text book image
Database System Concepts
Computer Science
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:McGraw-Hill Education
Text book image
Starting Out with Python (4th Edition)
Computer Science
ISBN:9780134444321
Author:Tony Gaddis
Publisher:PEARSON
Text book image
Digital Fundamentals (11th Edition)
Computer Science
ISBN:9780132737968
Author:Thomas L. Floyd
Publisher:PEARSON
Text book image
C How to Program (8th Edition)
Computer Science
ISBN:9780133976892
Author:Paul J. Deitel, Harvey Deitel
Publisher:PEARSON
Text book image
Database Systems: Design, Implementation, & Manag...
Computer Science
ISBN:9781337627900
Author:Carlos Coronel, Steven Morris
Publisher:Cengage Learning
Text book image
Programmable Logic Controllers
Computer Science
ISBN:9780073373843
Author:Frank D. Petruzella
Publisher:McGraw-Hill Education