Personal tools
20.3 Example Program - Roots of a Polynomial
data:image/s3,"s3://crabby-images/5ad7b/5ad7b7aa516834a78ce2445481c5784b9295f83b" alt=""
data:image/s3,"s3://crabby-images/ff5a3/ff5a311f9bd29c530ac38d11471422e10c9e4926" alt=""
data:image/s3,"s3://crabby-images/80b62/80b627ff6156915b6b0b31e9a9e4185040e49834" alt=""
data:image/s3,"s3://crabby-images/4c0ec/4c0ec2f255030e24311cd5ae132ff35562605b4f" alt=""
data:image/s3,"s3://crabby-images/a32ad/a32ade7402022dc9af0740b7731e94af217b8570" alt=""
Click on the banner to return to the user guide home page.
20.3 Example Program - Roots of a Polynomial
data:image/s3,"s3://crabby-images/4c8a8/4c8a8235843b0e556e37041f86018405bf6eaee5" alt=""
The roots of a polynomial a x2 + b x + c = 0 are given by the formula:
x = (-b _ sqrt(b2 - 4ac))/2a
The following program takes as input three double precision numbers, and returns the complex roots as a pair of values.
typedef complex<double> dcomplex; pair<dcomplex, dcomplex> quadratic (dcomplex a, dcomplex b, dcomplex c) // return the roots of a quadratic equation { dcomplex root = sqrt(b * b - 4.0 * a * c); a *= 2.0; return make_pair( (-b + root)/a, (-b - root)/a); }
data:image/s3,"s3://crabby-images/ff5a3/ff5a311f9bd29c530ac38d11471422e10c9e4926" alt=""
data:image/s3,"s3://crabby-images/80b62/80b627ff6156915b6b0b31e9a9e4185040e49834" alt=""
data:image/s3,"s3://crabby-images/4c0ec/4c0ec2f255030e24311cd5ae132ff35562605b4f" alt=""
data:image/s3,"s3://crabby-images/a32ad/a32ade7402022dc9af0740b7731e94af217b8570" alt=""
©Copyright 1996, Rogue Wave Software, Inc.