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
[5 marks] Give a recursive definition for the language anb2n where n = 1, 2, 3, ... over the alphabet Ó={a, b}. 2) [12 marks] Consider the following languages over the alphabet ƒ={a ,b}, (i) The language of all words that begin and end an a (ii) The language where every a in a word is immediately followed by at least one b. (a) Express each as a Regular Expression (b) Draw an FA for each language (c) For Language (i), draw a TG using at most 3 states (d) For Language (ii), construct a CFG.
Question 1 Generate a random sample of standard lognormal data (rlnorm()) for sample size n = 100. Construct histogram estimates of density for this sample using Sturges’ Rule, Scott’s Normal Reference Rule, and the FD Rule. Question 2 Construct a frequency polygon density estimate for the sample in Question 1, using bin width determined by Sturges’ Rule.
Generate a random sample of standard lognormal data (rlnorm()) for sample size n = 100. Construct histogram estimates of density for this sample using Sturges’ Rule, Scott’s Normal Reference Rule, and the FD Rule.
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