Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 26.10.2014
Сообщений: 31

Найти количество корней квадратного уравнения через метод с параметром

05.03.2015, 19:10. Показов 3521. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пожалуйста, помогите. Желательно решение по-простенькому. методом найти количество корней квадратного уравнения (параметры: коэффициенты уравнения). Метод возвращает 0, если корней нет, 1 – если корни одинаковые, 2 – два разных корня, -1 – если входные данные некорректны.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.03.2015, 19:10
Ответы с готовыми решениями:

Определить количество корней квадратного уравнения
С клавиатуры вводятся действительные числа A, B, C, которые являются коэффициентами квадратного уравнения вида Ax2 + Bx + C = 0 (при A...

Тест на проверку корней квадратного уравнения
Тест на проверку корней квадратного уравнения. Ругается на Имя "SqrtRoots" отсутствует в данном контексте. public void...

Программа для вычисления корней квадратного уравнения
Написать программу для вычисления корней квадратного уравнения. Пользователь вводит константы квадратного...

3
 Аватар для Lexeq
1151 / 743 / 483
Регистрация: 21.01.2014
Сообщений: 1,903
05.03.2015, 20:54
Через дискриминант достаточно просто?
https://ru.wikipedia.org/wiki/Дискриминант
0
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
06.03.2015, 01:57
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

Цитата Сообщение от Новичок1 Посмотреть сообщение
Желательно решение по-простенькому. методом найти количество корней квадратного уравнения
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
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
using System;
 
namespace ConsoleApplication169
{
    class Program
    {
        static void Main(string[] args)
        {
            //создаем фабрику
            var factory = new SquareEquationDoubleFactory();
            //создаем уравнение
            var eq = factory.CreateEquation(new double[]{2.3, 6.0, 3.0});
            //создаем решатель
            var solver = factory.CreateSolver();
            //вычисляем число решений
            var solveCount = solver.GetSolveCount(eq);
            //выводим
            switch(solveCount)
            {
                case 0: Console.WriteLine("Нет корней"); break;
                case 1: Console.WriteLine("Корни одинаковые"); break;
                case 2: Console.WriteLine("Два разных корня"); break;
            }
            //
            Console.ReadLine();
        }
    }
 
    public abstract class EquationAbstractFactory<T>
    {
        public abstract ISolver<T> CreateSolver();
        public abstract IEquation<T> CreateEquation(T[] coefficients);
    }
 
    public class SquareEquationDoubleFactory : EquationAbstractFactory<double>
    {
        public override ISolver<double> CreateSolver()
        {
            return new SquareSolverDouble();
        }
 
        public override IEquation<double> CreateEquation(double[] coefficients)
        {
            var eq = new SquareEquation<double>() { A = coefficients[0], B = coefficients[1], C = coefficients[2] };
            var adapter = new SquareEquationAdapter<double>(eq);
            return adapter;
        }
    }
 
    public class SquareSolverDouble: ISolver<double> 
    {
        public int GetSolveCount(IEquation<double> equation)
        {
            var coefficients = equation.GetCoefficients();
            if (coefficients.Length != 3)
                throw new ArgumentException();
 
            var d = CalcDiscriminant(coefficients);
 
            if (d < -double.Epsilon) return 0;
            if (d > double.Epsilon) return 2;
            return 1;
        }
 
        private double CalcDiscriminant(double[] coefficients)
        {
            var b = coefficients[1];
            var a = coefficients[0];
            var c = coefficients[2];
 
            return b * b - 4 * a * c;
        }
    }
 
    public interface ISolver<T>
    {
        int GetSolveCount(IEquation<T> equation);
    }
 
    public interface IEquation<T>
    {
        T[] GetCoefficients();
    }
 
    public abstract class BaseEquation
    {
        public abstract int CoefficientsCount { get; }
    }
 
    public class SquareEquation<T> : BaseEquation
    {
        public T A { get; set; }
        public T B { get; set; }
        public T C { get; set; }
    
        public override int  CoefficientsCount
        {
            get { return 3; }
        }
    }
 
    public abstract class BaseEquationAdapter<T> : IEquation<T>
    {
        protected BaseEquation equation;
 
        public BaseEquationAdapter(BaseEquation equiation)
        {
            this.equation = equiation;
        }
 
        public abstract T[] GetCoefficients();
    }
 
    public class SquareEquationAdapter<T> : BaseEquationAdapter<T>
    {
        public SquareEquationAdapter(SquareEquation<T> equiation) : base(equiation)
        {
        }
 
        public override T[] GetCoefficients()
        {
            var sqaureEquation = equation as SquareEquation<T>;
            return new T[] {sqaureEquation.A, sqaureEquation.B, sqaureEquation.C};
        }
    }
}
1
 Аватар для ture
553 / 361 / 206
Регистрация: 27.11.2014
Сообщений: 1,049
06.03.2015, 15:21
Лучший ответ Сообщение было отмечено tezaurismosis как решение

Решение

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
using System;
 
namespace cyber1 {
    class Program {
        static int CoutRoot(double a, double b, double c) {
            int rez;
            double d;
            if (a==0)
                rez=1;
            else if ((d=b*b-4*a*c)<0)
                rez=0;
            else if (d==0)
                rez=1;
            else
                rez=2;
 
            return rez;
        }
        static void Main() {
            //Спрашиваем
            Console.WriteLine("Вычисление количества корней уравнения:\n\ta*x^2+b*x+c=0");
            Console.Write("\ta = ");
            double a=double.Parse(Console.ReadLine().Replace(".",","));
            Console.Write("\tb = ");
            double b=double.Parse(Console.ReadLine().Replace(".", ","));
            Console.Write("\tc = ");
            double c=double.Parse(Console.ReadLine().Replace(".", ","));
 
            //Отвечаем
            Console.Write("Уравнение:\n\t{0}*x^2 {3} {1}*x {4} {2} = 0\nимеет {5}", a, b, c, b<0? "":"+", c<0? "":"+",CoutRoot(a, b, c));
 
            Console.ReadLine();
        }
    }
}
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.03.2015, 15:21
Помогаю со студенческими работами здесь

Программа для поиска корней квадратного уравнения
Общее задание: Даны коэффициенты квадратного уравнения a, b, c. Написать программу для поиска корней этого квадратного уравнения....

Нахождение корней квадратного уравнения (исправить код)
так чтобы при отрицательном дискриминате программа выводила сообщение &quot;Нет корней. Если дискриминат равен 0 то программа должна выводить...

Программа вычисления корней квадратного уравнения вида ax2+bx+c = 0
Всем доброго времени суток, друзья. Вот такая вот задача мне выпала от препода. Поможете решить? Написать программу вычисления корней...

Написать программу вычисления корней квадратного уравнения вида ax2+bx+c = 0
Написать программу вычисления корней квадратного уравнения вида ax2+bx+c = 0. Значения a, b и c вводить в режиме диалога. Предусмотреть...

Найти количество действительных корней квадратного уравнения
не могу найти ошибку.Компилятор ругается Суть задачи : Определить кол-во действительных корней квадратного уравнения ax^2+bx+c=0 с...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru