Personal tools
20.3 Example Program - Roots of a Polynomial
data:image/s3,"s3://crabby-images/4708e/4708eb96c6921088b98d58fc8d6c50d14a5b4bda" alt=""
data:image/s3,"s3://crabby-images/a6442/a644201ea1e5b6d308291c477952cfd8702e93f4" alt=""
data:image/s3,"s3://crabby-images/cbc04/cbc0467d87b5156b4cefb8a3c14e477c04e69a55" alt=""
data:image/s3,"s3://crabby-images/4f0f7/4f0f7063b84e30bcc985b38de5e467d7c8f33832" alt=""
data:image/s3,"s3://crabby-images/b77b9/b77b900a2ca82081926cdbe552d45fd367773ccc" 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/5c223/5c2231dfab697f94be7f2fd982cd93573362202a" 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/a6442/a644201ea1e5b6d308291c477952cfd8702e93f4" alt=""
data:image/s3,"s3://crabby-images/cbc04/cbc0467d87b5156b4cefb8a3c14e477c04e69a55" alt=""
data:image/s3,"s3://crabby-images/4f0f7/4f0f7063b84e30bcc985b38de5e467d7c8f33832" alt=""
data:image/s3,"s3://crabby-images/b77b9/b77b900a2ca82081926cdbe552d45fd367773ccc" alt=""
©Copyright 1996, Rogue Wave Software, Inc.