Personal tools
20.3 Example Program - Roots of a Polynomial
data:image/s3,"s3://crabby-images/4e8f8/4e8f8d6b6a65f3a34225b132a0e467256f839c40" alt=""
data:image/s3,"s3://crabby-images/45250/45250b9b63f2656cb1a8625525077875c774b703" alt=""
data:image/s3,"s3://crabby-images/df0e1/df0e1711b517332b384c854bd5d1ecaa390fb5b7" alt=""
data:image/s3,"s3://crabby-images/8ea65/8ea65de15fb1cd8fcedcb15830465320fe4de866" alt=""
data:image/s3,"s3://crabby-images/5a7fc/5a7fc5be0a5df04b23ece49f46734f8b0b6dc156" 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/1cf02/1cf027535bd1bf4b5ea24f75f9a29f79d3234378" 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/45250/45250b9b63f2656cb1a8625525077875c774b703" alt=""
data:image/s3,"s3://crabby-images/df0e1/df0e1711b517332b384c854bd5d1ecaa390fb5b7" alt=""
data:image/s3,"s3://crabby-images/8ea65/8ea65de15fb1cd8fcedcb15830465320fe4de866" alt=""
data:image/s3,"s3://crabby-images/5a7fc/5a7fc5be0a5df04b23ece49f46734f8b0b6dc156" alt=""
©Copyright 1996, Rogue Wave Software, Inc.