Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Функции. Написать функцию решения квадратного уравнения - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Сортировка по убыванию с использованием указателя http://www.cyberforum.ru/cpp-beginners/thread799644.html
Все перепробовала, у меня никак не получается сделать сортировку по убыванию с указателем. Можете дописать часть кода? #include<iostream> #include <math.h> #include<stdlib.h> #include <ctime>...
C++ Исправьте ошибку string subscript out of range #include <iostream> #include <string> #include <vector> using namespace std; int main () { string s = "222/2"; string* s2 = new string ; string delimiters = "+ * / - ( )"; http://www.cyberforum.ru/cpp-beginners/thread799633.html
оператор-друг для нешаблонного класса, вложенного в шаблонный C++
Привет! Суть проблемы в заголовке темы. Пример того, что мне надо. template <class T> class A { public: class B {
C++ [Теория] Преобразование Struct * <=> Type *
Здравствуйте, Господа и Дамы. Немного теории, коротко и без зевоты. Итак, есть структура с однотипными переменными. struct coordinat3f{ float x, y, z; }; coordinat3f coord; и есть указатель...
C++ нейронные сети (адаптивные сети) http://www.cyberforum.ru/cpp-beginners/thread799581.html
нужен исходник 3д или 2д адаптивной сетки для небольшого использования в своей работе (растягивалась что бы на какуюнить фигуру на плоскости или в пространстве) а так же желательно рекомендации...
C++ Объясните, как создать класс Описать класс, включающий заданные поля и функции. Разработать программу, которая создает массив объектов (размерность массива n вводится с клавиатуры) и выполняет требуемые действия. Класс -... подробнее

Показать сообщение отдельно
lemegeton
2925 / 1354 / 135
Регистрация: 29.11.2010
Сообщений: 2,725
03.03.2013, 21:07
С учетом комплексных корней, вырожденых уравнений...
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
#include <ctime>
#include <iomanip>
#include <iostream>
#include <cmath>
 
const int EPSILON = 0.00001;
 
class Complex {
 public:
  Complex() : real(0), imaginary(0) {};
  Complex(double real) : real(real), imaginary(0) {}
  Complex(const double &real, const double &imaginary) : real(real), 
    imaginary(imaginary) {}
  const double &getReal() const { return real; }
  const double &getImaginary() const { return imaginary; }
 private:
  double real, imaginary;
};
 
Complex operator+(const Complex &a, const Complex &b) {
  return Complex(a.getReal() + b.getReal(), a.getImaginary() + b.getImaginary());
}
 
Complex operator-(const Complex &a, const Complex &b) {
  return Complex(a.getReal() - b.getReal(), a.getImaginary() - b.getImaginary());
}
 
Complex operator*(const Complex &a, const Complex &b) {
  return Complex(
    a.getReal() * b.getReal() - a.getImaginary() * b.getImaginary(),
    a.getReal() * b.getImaginary() + a.getImaginary() * b.getReal());
}
 
Complex operator/(const Complex &a, const Complex &b) {
  return Complex(
    (a.getReal() * b.getReal() + a.getImaginary() * b.getImaginary()) /
    (b.getReal() * b.getReal() + b.getImaginary() * b.getImaginary()),
    (a.getImaginary() * b.getReal() - a.getReal() * b.getImaginary()) /
    (b.getReal() * b.getReal() + b.getImaginary() * b.getImaginary()));
}
 
std::ostream &operator<<(std::ostream &stream, const Complex &number) {
  stream << std::setprecision(4) << std::fixed << number.getReal();
  if (fabs(number.getImaginary()) > EPSILON) {
    stream << ((number.getImaginary() > 0)? "+" : "") << number.getImaginary() << "i"; 
  }
  return stream;
};
 
class QuadraticEquation {
 public:
  QuadraticEquation(const double &a, const double &b, const double &c)
    : x1(), x2(), discriminant(0), numberOfRoots(0), a(a), b(b), c(c) {
    solve();
  }
  double getA() const { return a; }
  double getB() const { return b; }
  double getC() const { return c; }
  double getDiscriminant() const { return discriminant; }
  Complex getX1() const { return x1; }
  Complex getX2() const { return x2; }
  double getNumberOfRoots() const { return numberOfRoots; }
 private:
  void solve() {
    if (a == 0 || fabs(a) < EPSILON) {
      if (b == 0 || fabs(b) < EPSILON) {
        numberOfRoots = 0;
      } else {
        numberOfRoots = 1;
        x1 = x2 = (-c) / b;
      }
      return;
    }
    discriminant = b * b - 4 * a * c;
    if (discriminant == 0 || fabs(discriminant) < EPSILON) {
      numberOfRoots = 1;
      x1 = x2 = (b * b) / (2 * a);
    } else if (discriminant < 0) {
      numberOfRoots = 2;
      x1 = Complex((-b) / (2 * a), sqrt(-discriminant) / (2 * a)); 
      x2 = Complex((-b) / (2 * a), -sqrt(-discriminant) / (2 * a)); 
    } else {
      numberOfRoots = 2;
      x1 = (-b + sqrt(discriminant)) / (2 * a);
      x2 = (-b - sqrt(discriminant)) / (2 * a);
    }
  }
  Complex x1, x2;
  double discriminant, numberOfRoots;
  double a, b, c;
};
 
std::ostream &operator<<(std::ostream &stream, const QuadraticEquation &equation) {
  std::cout << equation.getA() << "*x^2" << ((equation.getB() >= 0) ? "+" : "") <<
    equation.getB() << "*x" <<((equation.getC() >= 0) ? "+" : "") <<
    equation.getC() << " = 0";
}
 
int main(int argc, char **argv) {
  QuadraticEquation a(0, 0, 0);
  
  std::cout << a << std::endl <<
    "number of roots: " << a.getNumberOfRoots() << std::endl <<
    "x1 = " << a.getX1() << std::endl <<
    "x2 = " << a.getX2() << std::endl;
 
  std::cin.get();
  return 0;
}
1
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru