Personal tools
20.3 Example Program - Roots of a Polynomial
data:image/s3,"s3://crabby-images/cd9c6/cd9c6da6aba267f4816248c04aeb0089a9ef78b0" alt=""
data:image/s3,"s3://crabby-images/6783f/6783f819b5f76b1ad97e977c32bdde8ad11a6666" alt=""
data:image/s3,"s3://crabby-images/e75c9/e75c939e20d7cd1522e390f313a2ae6a96bf8f9c" alt=""
data:image/s3,"s3://crabby-images/cddf7/cddf79263dfed8836fb82e5b4e5628b6f04f27ca" alt=""
data:image/s3,"s3://crabby-images/6e4f3/6e4f33ecaad8338b7d1ecc9eafc4d26371e2de2a" 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/90814/90814476fd9ca203b43eccd5fc5b5e2b34efa1de" 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/6783f/6783f819b5f76b1ad97e977c32bdde8ad11a6666" alt=""
data:image/s3,"s3://crabby-images/e75c9/e75c939e20d7cd1522e390f313a2ae6a96bf8f9c" alt=""
data:image/s3,"s3://crabby-images/cddf7/cddf79263dfed8836fb82e5b4e5628b6f04f27ca" alt=""
data:image/s3,"s3://crabby-images/6e4f3/6e4f33ecaad8338b7d1ecc9eafc4d26371e2de2a" alt=""
©Copyright 1996, Rogue Wave Software, Inc.