Нахождение корней кубического уравнения - C#

Узнай цену своей работы

Формулировка задачи:

Всем, привет. Столкнулся с проблемой написания формулы решения кубического уравнения, а точнее нахождения их корней. Ниже есть код, который я писал. Как оказалось, формула, которую я писал по видимому не находит корней. Ссылка на сайт с формулой. Это глупый вопрос, но формула указанная на сайте находить корни? Если не составит труда, не могли бы вы оставить готовый код, для нахождения корней в кубическом уравнении, если он у вас есть!)) Сам код, который я писал(читайте комментарии):
// Эта формула взята с сайта "http://planetcalc.ru/1122/" В плане конвертирования математического вида теоремы в программный, вроде все нормально написал, но есть проблемки! 
            Console.Write("Введите А ");
            int a = Int32.Parse(Console.ReadLine());
            Console.Write("Введите В ");
            int b = Int32.Parse(Console.ReadLine());
            Console.Write("Введите C ");
            int c = Int32.Parse(Console.ReadLine());
            double Q = (Math.Pow(a, 2) - 3 * b) / 9;
            double R = (2 * Math.Pow(a, 3) - 9 * a * b + 27 * c) / 54;
            double S = Math.Pow(Q, 3) - Math.Pow(R, 2);
            double fi = 1 / 3 * Math.Acos(R / Math.Sqrt(Math.Pow(Q, 3)));
            double x1;
            double x2;
            double x3;
            double x23;
            double i; // С этой переменной возникают проблемы. У нее нету значения, но по формуле ее нужно писать.
            {if (S > 0)
            {
                x1 = -2 * Math.Sqrt(Q) * Math.Cos(fi) - a / 3;
                x2 = -2 * Math.Sqrt(Q) * Math.Cos(fi + 2 / 3 * Math.PI) - a / 3;
                x3 = -2 * Math.Sqrt(Q) * Math.Cos(fi - 2 / 3 * Math.PI) - a / 3;
            }
            else
            {
                if (Q > 0)
                {
                    fi = 1 / 3 * Math.Log(Math.Abs(R) / Math.Sqrt(Math.Pow(Q, 3))) + Math.Sqrt(Math.Pow(Math.Abs(R) / Math.Sqrt(Math.Pow(Q, 3)), 2) - 1);
                    x1 = -2 * Math.Sign(R) * Math.Sqrt(Q) * 2 / (Math.Exp(fi) - Math.Exp(-fi)) - a / 3;
                    x23 = Math.Sign(R) * Math.Sqrt(Q) * 2 / (Math.Exp(fi) - Math.Exp(-fi)) - a / 3 +- i * Math.Sqrt(3) * Math.Sqrt(Q) * 2 / (Math.Exp(fi) + Math.Exp(-fi));
                }
                else
                {
                    fi = 1 / 3 * Math.Log(Math.Abs(R) / Math.Sqrt(Math.Abs(Q)), 3);
                    x1 = -2 * Math.Sign(R) * Math.Sqrt(Math.Abs(Q)) * ((Math.Exp(fi) - Math.Exp(-fi)) / 2) - a / 3;
                    x23 = Math.Sign(R) * Math.Sqrt(Math.Abs(Q)) * ((Math.Exp(fi) - Math.Exp(-fi)) / 2) - a / 3 +- i * Math.Sqrt(3) * Math.Sqrt(Math.Abs(Q)) * 2 / (Math.Exp(fi) - Math.Exp(-fi);
                }
            }
            }
            
            if (S == 0)
            {
                x1 = (-2 * Math.Sign(R) * Math.Sqrt(Q) - a / 3) = (-2 * Math.Sqrt(R) - a / 3); // Возникла проблема в написании самого вырожения. Я код не правильно написал?(Взгляните на сайт. Вроде все правильно написал)
            }
            // Я код не закончил, т.к. возникли вышеперечисленные проблемы

Решение задачи: «Нахождение корней кубического уравнения»

textual
Листинг программы
x23 = Math.Sign(R) * Math.Sqrt(Q) * 2 / (Math.Exp(fi) - Math.Exp(-fi)) - a / 3 - i * Math.Sqrt(3) * Math.Sqrt(Q) * 2 / (Math.Exp(fi) + Math.Exp(-fi)); // x2 = x3: -

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

6   голосов , оценка 4.333 из 5
Похожие ответы