How We Hire Writers

custom writing

All applicants go through a series of tests that check their level of English and knowledge of formatting styles. The applicant is also required to present a sample of writing to the Evaluation Department. If you wish to find out more about the procedure, check out the whole process.

How We Ensure Quality

Our Quality Control Department checks every single order for formatting, style, word usage, and authenticity. This lets us deliver certified assignment assistance that has no Internet rivals.

C++, operator overloading

You can only use standard c++ libraries. The key is to use fractions .

This assignment will be about numbers: your goal will be to

implement a class, number, which represents a real number with an

arbitrary number of digits (also known as an arbitrary precision

number). The class should have operators for addition, subtraction,

multiplication, division and comparisons, as well as unary minus.

Additionally, add power( int ) and sqrt( int ) as const

methods. The argument to power is the exponent. The argument of

sqrt gives the number of decimal digits that should be exact in

the result (see also below).

The constructor of number takes a single integer argument and

constructs an instance of number with the argument as its value

(this constructor should allow implicit conversions from int). A

default-constructed number should be 0.

As an example, all of the following should be valid code:

  number a( 10 ), b( 25 );

  number c = a + b;

  number d = c / a;

  number e = d * a;

  assert( e == a + b );

  assert( e != a );

  assert( c > a );

  assert( a < b );

  assert( c.power( 2 ) > c );

  c = number( 10 ).power( -5 );

  assert( c > c.power( 2 ) );

The decimal digits supplied to sqrt should be interpreted as

follows:

  number s = number( 145 ).sqrt( 3 ); /* 3 fractional digits */

  /* the exact result rounded to 3 fractional places is 12.042 */

  number lower = number( 120415 ) * number( 10 ).power( -4 );

  number upper = number( 120425 ) * number( 10 ).power( -4 );

  assert( s > lower );

  assert( s < upper );

Or in other words, if your result is (single) rounded to the given

number of decimal places, it must agree in all those decimal places

with a correctly rounded exact result.

Division by zero and square roots of negative numbers are undefined.

PS: A reference solution is about 250 lines of not very dense code.

You can leave a response, or trackback from your own site.

Leave a Reply

Powered by WordPress | Designed by: Premium WordPress Themes | Thanks to Themes Gallery, Bromoney and Wordpress Themes