Алгоритм решения данной задачи сначала должен быть представлен в виде словесного описания или графически в виде блок-схемы. Алгоритм вычисления корней квадратного уравнения может быть представлен в виде блок-схем, изображенных на рисунках, отображающих основные элементы блок-схем и алгоритм вычисления корней квадратного уравнения:
Изображение алгоритма в виде блок-схемы позволяет наглядно представить последовательность действий, необходимых для решения поставленной задачи, убедиться самому программисту в правильности понимания поставленной задачи.
После разработки алгоритма решения задачи и представления его в виде блок-схемы можно перейти к написанию программы – последовательности инструкций на выбранном языке программирования, соответствующей разработанному алгоритму. Например, ниже приведен фрагмент программы решения квадратного уравнения, соответствующий приведенному выше алгоритму, составленному на языке Visual Basic.
procedure SqRoot(Editi,Edit2,Edit3:tEdit;Label2:tLabel);
var
a,b,c:real;
d:real;
xl,x2:real;
begin
a:=StrToFloat(Editl.text);
b:=StrToFloat(Edit2.text);
с:=StrToFloat(Edj.t3.text);
d:=Sqr(b)-4*a*c;
if d=0 then begin
Label2.color:=clRed;
Label2.font.color:=clRed;
Label2.caption:=’Дискриминант меньше нуля.’+#13+
‘Уравнение не имеет корней.’ end else
begin
х1:=(-b+Sqrt(d))/(2*a);
x2:=(-b-Sqrt(d))/(2*а);
Label2.font.color:=clBlack;
Label 2.caption=’Корни уравнения:’ +#13+’xl=1+FloatToStr(xl)
+#13+’x2=’+FloatToStr(x2);
end;
end.
Но программа, написанная на языке программирования, состоит из инструкций, понятных человеку, но не понятных процессору компьютера. Поэтому чтобы процессор смог выполнить работу в соответствии с инструкциями исходной программы, она должна быть переведена на язык команд процессора, то есть машинный язык. Задачу преобразования исходной программы в машинный код выполняет специальная программа — компилятор. Помимо преобразования исходной программы в машинную, компилятор выполняет проверку правильности записи инструкций исходной программы, т. е. осуществляет синтаксический анализ.
Компилятор создает исполняемую программу только в том случае, если в тексте исходной программы нет синтаксических ошибок. Однако генерация исполняемой программы машинного кода свидетельствует только об отсутствии в тексте программы синтаксических ошибок. Убедиться в правильности работы программы можно только во время ее тестирования – пробных запусках программы и при анализе полученных результатов. Например, если в программе нахождения корней квадратного уравнения допущена ошибка в записи выражения вычисления дискриминанта, то даже если это выражение будет синтаксически верно, программа выдаст неверные значения корней.
Решение квадратных уравнений средствами Visual Basic
Задача: Дано квадратное уравнение общего вида: ax 2 +bx+c=0. Ввести в память компьютера числовые коэффициенты: a, b, c, выполнить необходимый анализ введенной информации согласно известному из курса средней школы алгоритму решения квадратного уравнения: найти дискриминант d=b 2 -4ac и, проанализировав его знак, найти все действительные корни, если знак дискриминанта положительный, или сообщить о том, что действительных корней нет, если знак дискриминанта отрицательный.
Начать составление проекта решения данной задачи необходимо с ответа на вопрос: что нужно поместить на форму Form1?
Поместим на форму две кнопки: CommandButton1 и CommandButton2.
Для этого нужно воспользоваться Панелью элементов (объектов) управления General, которая расположена в левой части основного окна компилятора Visual Basic.
Первая кнопка CommandButton1 предназначается для начала работы программы согласно следующему алгоритму:
- ввод коэффициентов исходного уравнения a, b, c;
- расчет дискриминанта d=b 2 — 4ac;
- анализ знака дискриминанта, вычисление корней уравнения и вывод их на форму, если знак дискриминанта d>0 (положительный);
- вывод сообщения: «Решений нет», если знак дискриминанта d 2 -5x+6=0.
Далее рассмотрим процесс решения второго квадратного уравнения: 10x 2 +5x+200=0.
В окне InputBox вводим значение первого коэффициента уравнения a=10.
Ввод первого коэффициента a завершается нажатием кнопки Ok.
Аналогично в окне InputBox вводим значение второго коэффициента уравнения b=5.
Ввод второго коэффициента b так же завершается нажатием соответствующей кнопки Ok.
Наконец, в окне InputBox вводим значение третьего коэффициента нового уравнения c=200.
Ввод третьего коэффициента c так же завершается нажатием соответствующей кнопки Ok.
После этого программа, проанализировав полученную информацию, должна выдать в окне формы соответствующее сообщение о том, что данное уравнение не имеет решений.
И, наконец, рассмотрим процесс решения третьего квадратного уравнения: x 2 -8x+16=0.
Это уравнение имеет двукратный корень, так как его дискриминант d=0. Как и в двух предыдущих случаях, вводим коэффициенты квадратного уравнения. Первым вводим коэффициент a=1.
Далее вводим второй коэффициент уравнения b= –8.
Третий коэффициент уравнения c=16 вводим в последнюю очередь.
В итоге мы должны увидеть правильное решение третьего квадратного уравнения. Действительно последнее уравнение имеет два одинаковых корня.
Видео:Блок-схемы для начинающих (Блок схемы алгоритмов)Скачать
Составить алгоритм нахождения корней квадратного уравнения в виде блок схемы
Copy raw contents
Основные алгоритмические конструкции
Алгоритм применительно к вычислительной машине — точное предписание, т.е. набор операций и правил их чередования, при помощи которого, начиная с некоторых исходных данных, можно решить любую задачу фиксированного типа.
Алгоритмы в зависимости от цели, начальных условий задачи, путей ее решения, определения действий исполнителя подразделяются следующим образом:
Линейный алгоритм — набор команд (указаний), выполняемых последовательно друг за другом.
Основным элементарным действием в линейных алгоритмах является присваивание значения переменной величине. Если значение константы определено видом ее записи, то переменная величина получает конкретное значение только в результате присваивания. Присваивание может осуществляться двумя способами: с помощью команды присваивания и с помощью команды ввода.
Рассмотрим пример. В школьном учебнике математики правила деления обыкновенных дробей описаны так:
- Числитель первой дроби умножить на знаменатель второй дроби.
- Знаменатель первой дроби умножить на числитель второй дроби.
- Записать дробь, числитель которой есть результат выполнения пункта 1, а знаменатель — результат выполнения пункта 2.
В алгебраической форме это выглядит следующим образом:
Построим алгоритм деления дробей для ЭВМ. В этом алгоритме сохраним те же обозначения для переменных, которые использованы в записанной выше формуле. Исходными данными являются целочисленные переменные а, Ь, с, d. Результатом — также целые величины m и n. Блок-схема и текст алгоритма на языке программирования (ЯП) Kotlin приведены ниже.
Формат команды присваивания следующий:
Знак «=» нужно читать как «присвоить».
Команда присваивания обозначает следующие действия, выполняемые компьютером:
- Вычисляется выражение.
- Полученное значение присваивается переменной.
В приведенном выше алгоритме присутствуют две команды присваивания. В блок-схемах команда присваивания записывается в прямоугольнике. Такой блок называется вычислительным блоком.
В описаниях алгоритмов необязательно соблюдать строгие правила в записи выражений. Их можно писать в обычной математической форме. Это еще не язык программирования со строгим синтаксисом.
В приведенном алгоритме присутствуют команды ввода:
В блок-схеме команда ввода записывается в параллелограмме — блоке ввода-вывода. При выполнении данной команды процессор прерывает работу и ожидает действий пользователя. Пользователь должен набрать на устройстве ввода (клавиатуре) значения вводимых переменных и нажать на клавишу ввода Enter. Обычно с помощью команды ввода присваиваются значения исходных данных, а команда присваивания используется для получения промежуточных и конечных величин.
Полученные компьютером результаты решения задачи должны быть сообщены пользователю. Для этих целей предназначена команда вывода:
С помощью этой команды результаты выводятся на экран или на устройство печати на бумагу.
Поскольку присваивание является важнейшей операцией в вычислительных алгоритмах, обсудим ее более подробно.
Рассмотрим последовательное выполнение четырех команд присваивания, в которых участвуют две переменные величины a и b.
В приведенной ниже таблице напротив каждой команды присваивания указываются значения переменных, которые устанавливаются после ее выполнения.
Команда | a | b |
---|---|---|
a=1 | 1 | — |
b=a*2 | 1 | 2 |
a=b | 2 | 2 |
b=a+b | 2 | 4 |
Этот пример иллюстрирует три основных свойства команды присваивания:
- пока переменной не присвоено значение, она остается неопределенной;
- значение, присвоенное переменной, сохраняется в ней вплоть до выполнения следующей команды присваивания этой переменной;
- новое значение, присваиваемое переменной, заменяет ее предыдущее значение.
Рассмотрим один очень полезный алгоритм, который приходится часто использовать при программировании. Даны две величины: Х и Y. Требуется произвести между ними обмен значениями. Например, если первоначально было Х=1, Y=2, то после обмена должно стать: Х=2, Y=1.
Хорошей моделью для решения этой задачи является следующая ситуация: имеются два стакана — один с молоком, другой с водой. Требуется произвести обмен их содержимым. Всякому ясно, что в этом случае нужен дополнительный третий пустой стакан. Последовательность действий будет следующей: 1) перелить из первого стакана в третий; 2) перелить из второго в первый; 3) перелить из третьего во второй. Цель достигнута!
По аналогии для обмена значениями двух переменных нужна третья дополнительная переменная. Назовем ее Z. Тогда задача обмена решается последовательным выполнением трех команд присваивания:
Команда | X | Y | Z |
---|---|---|---|
ввод X, Y | 1 | 2 | — |
Z = X | 1 | 2 | 1 |
X = Y | 2 | 2 | 1 |
Y = Z | 2 | 1 | 1 |
Аналогия со стаканами не совсем точна в том смысле, что при переливании из одного стакана в другой первый становится пустым. В результате же присваивания (Х = Y) переменная, стоящая справа (Y), сохраняет свое значение.
Алгоритм для деления дробей имеет линейную структуру. В нем все команды выполняются в строго однозначной последовательности, каждая по одному разу. Линейный алгоритм составляется из команд присваивания, ввода, вывода и обращения к вспомогательным алгоритмам (об этом позже).
При описании алгоритмов в блок-схемах типы, как правило, не указываются (но подразумеваются). В алгоритмах для всех переменных типы указываются явно. В них используются следующие обозначения типов: Int — целый тип, Float — вещественный тип, String — символьный (литерный) тип, Boolean — логический тип. В алгоритме для деления дробей для всех переменных указан тип Int.
Разветвляющийся алгоритм — алгоритм, содержащий хотя бы одно условие, в результате проверки которого ЭВМ обеспечивает переход на один из двух возможных шагов.
Циклический алгоритм — алгоритм, предусматривающий многократное повторение одного и того же действия (одних и тех же операций) над новыми исходными данными. К циклическим алгоритмам сводится большинство методов вычислений, перебора вариантов. Цикл программы — последовательность команд (серия, тело цикла), которая может выполняться многократно (для новых исходных данных) до удовлетворения некоторому условию.
Составим алгоритм решения квадратного уравнения: ax 2 +bx+c=0
Задача хорошо знакома из математики. Исходными данными здесь являются коэффициенты а, b, с. Решением в общем случае будут два корня х1 и х2, которые вычисляются по формуле:
Слабость такого алгоритма видна невооруженным глазом. Он не обладает важнейшим свойством, предъявляемым к качественным алгоритмам, — универсальностью по отношению к исходным данным. Какими бы ни были значения исходных данных, алгоритм должен приводить к определенному результату и завершать работу. Результатом может быть число, но может быть и сообщение о том, что при определенных данных задача решения не имеет. Недопустимы остановки в середине алгоритма из-за невозможности выполнить какую-то операцию. Упомянутое свойство называют результативностью алгоритма (в любом случае должен быть получен какой-то результат).
Чтобы построить универсальный алгоритм, сначала требуется тщательно проанализировать математическое содержание задачи.
Решение уравнения зависит от значений коэффициентов а, b, с. Вот анализ рассмотренной выше задачи (ограничиваемся только поиском вещественных корней):
если а = 0, b = 0, с = 0, то любое х — решение уравнения;
если а = 0, b = 0, с О, то уравнение действительных решений не имеет;
если а = 0, b О, то это линейное уравнение, которое имеет одно решение х = -c/b;
если а0 и d=b 2 -4ac >= 0, то уравнение имеет два вещественных корня (формулы приведены выше);
если a0 и d N, то НОД(М, N) = НОД(М-N,N). Другой факт, лежащий в основе алгоритма, тривиален — НОД(М, М) = М. Для «ручного» выполнения этот алгоритм можно описать в форме следующей инструкции:
- Если числа равны, то взять их общее значение в качестве ответа; в противном случае продолжить выполнение алгоритма
- Определить большее из чисел
- Заменить большее число разностью большего и меньшего значений
- Вернуться к выполнению пункта 1
Алгоритм имеет структуру цикла с вложенным ветвлением. Проделайте самостоятельно трассировку этого алгоритма для случая М = 18, N = 12. В результате получится НОД = 6, что, очевидно, верно.
Вспомогательные алгоритмы и процедуры
В теории алгоритмов известно понятие вспомогательного алгоритма. Вспомогательным называется алгоритм решения некоторой подзадачи из основной решаемой задачи. В таком случае алгоритм решения исходной задачи называется основным алгоритмом.
В качестве примера рассмотрим следующую задачу: требуется составить алгоритм вычисления степенной функции с целым показателем у = х к , где к — целое число, х0. В алгебре такая функция определена следующим образом:
Для данной задачи в качестве подзадачи можно рассматривать возведение числа в целую положительную степень.
Учитывая, что 1/х -n = (1/х) -n , запишем основной алгоритм решения этой задачи.
Здесь дважды присутствует команда обращения к вспомогательному алгоритму с именем stepen. Это алгоритм возведения вещественного основания в целую положительную степень путем его многократного перемножения. Величины, стоящие в скобках в команде обращения к вспомогательному алгоритму, называются фактическими параметрами.
В котлине вспомогательные алгоритмы оформляются в виде функций. Запишем функцию stepen.
Заголовок вспомогательного алгоритма начинается с ключевого слова fun, после которого следует имя функции, в скобках — список формальных параметров и после скобок тип результата (не обязателен). В списке параметров перечисляются переменные-аргументы с указанием их типов. Здесь x и n — формальные параметры-аргументы. Следовательно, процедура stepen производит вычисления по формуле а к . В основном алгоритме «Степенная функция» обращение к процедуре производится путем указания ее имени с последующим в скобках списком фактических параметров. Между формальными и фактическими параметрами процедуры должны выполняться следующие правила соответствия:
- по количеству (сколько формальных, столько и фактических параметров)
- по последовательности (первому формальному соответствует первый фактический параметр, второму — второй и т.д.)
- по типам (типы соответствующих формальных и фактических параметров должны совпадать)
Фактические параметры-аргументы могут быть выражениями соответствующего типа.
Обращение к процедуре инициирует следующие действия:
- Значения параметров-аргументов присваиваются соответствующим формальным параметрам.
- Выполняется тело процедуры (команды внутри процедуры).
- Значение результата возвращается командой return, и происходит переход к выполнению следующей команды основного алгоритма.
В функции stepen нет команд ввода исходных данных и вывода результатов. Здесь присваивание начальных значений аргументам (x, n) производится через передачу параметров-аргументов. А получение результата происходит командой return. Таким образом, передача значений параметров процедур — это третий способ присваивания (наряду с командой присваивания и командой ввода).
Использование процедур позволяет строить сложные алгоритмы методом последовательной детализации.
Программы для графического отображения алгоритмов
Видео:Решение квадратных уравнений. Дискриминант. 8 класс.Скачать
Решение квадратных уравнений на компьютере
-Муниципальное общеобразовательное учреждение
Кувакинская средняя общеобразовательная школа
Учитель информатики МОУ «Кувакинская СОШ»
с Кувакино, 2011
Как реализуется метод решения квадратных уравнений на компьютере.
Алгоритм решения данной задачи сначала должен быть представлен в виде словесного описания или графически в виде блок-схемы. Алгоритм вычисления корней квадратного уравнения может быть представлен в виде блок схем, изображенных на следующих рисунках:
Изображение алгоритма в виде блок-схемы позволяет наглядно представить последовательность действий, необходимых для решения поставленной задачи, убедиться самому программисту в правильности понимания поставленной задачи.
После разработки алгоритма решения задачи и представления его в виде блок-схемы можно перейти к написанию программы – последовательности инструкций на выбранном языке программирования, соответствующей разработанному алгоритму. Например, ниже приведен фрагмент программы решения квадратного уравнения, соответствующий приведенному выше алгоритму, составленному на языке Turbo Pascal.
if D 0 then writeln ( ‘x1=’,(-b+sqrt(D))/(2*a)); writeln (‘x2=’, (-b-sqrt(D));
2. РЕШЕНИЕ КВАДРАТНЫХ УРАВНЕНИЙ СРЕДСТВАМИ EXCEL
2.1 Решение квадратных уравнений в Eхcel.
В ячейку А1 набираем фразу «Решение квадратного уравнения вида Ах2+Вх+С=0», и выделяем ячейки строки А от 1 до той которая находится перед пунктирной линией. Форматируем расположение, начертание и размер букв через опцию ЯЧЕЙКИ меню ФОРМАТ. В подпанели Выравнивание устанавливаем значение «Центрировать по выделению». В подпанели Шрифт — размер и начертание букв (у нашем варианте это полужирный курсив и размер 14). Устанавливаем курсор на ячейке В4 и набираем А=, в ячейке В5 — В=, в ячейке В6 — С=, и производим форматирование по описанному выше методу. Ячейки С4, С5 и С6 выделяем рамкой в подпанели Рамка панели ЯЧЕЙКИ меню ФОРМАТ. Эти ячейки предназначены для ввода в них значений А, В, С.
Набор формулы. В ячейках Е4 и Е6 пишем соответственно х1= и х2=, и форматируем по методу, описанному выше. А в ячейки F4 и F6 записываем формулы так. Сначала ставится равно, потом значение ячейки В5 нажатием на ней мышки, функция Корень вставляется из пункта меню ВСТАВКА — ФУНКЦИЯ. Выбираем из математических функций — КОРЕНЬ. И нажимаем кнопку Далее — для ввода значения, находящегося под корнем. Следуя формуле дискриминанта вводим B5^2-(4*B4*B6), а общий вид формулы — =(-B5 + КОРЕНЬ(B5^2-(4*B4*B6)))/(2*B4) Такую же формулу вставляем и в ячейку F6, но со знаком минус: =(-B5 — КОРЕНЬ(B5^2-(4*B4*B6)))/(2*B4) Теперь после ввода пользователем значений А, В,С в ячейки В4, В5 и В6, в ячейках F4 и F6 будут выводится соответственно значения х1 и х2.
2.2 Нахождение корней квадратного уравнения с помощью
логических функций.
В ячейку А1 набираем фразу «Решение квадратного уравнения вида Ах2+Вх+С=0»,
В ячейку А2 записываем А=, А3 – В=, в А4 – С=. Ячейки В2. В3, В4 выделяем рамкой.
В ячейки D2, D3, D4 записываем соответственно D=, x1=, x2=.
Напишем формулу для подсчета дискриминанта в информатике =В3*В3+4*В2*В4.
Теперь запишем формулы, используя функцию “ЕСЛИ”:
- Для X1: =ЕСЛИ(E2>0;(-B3-КОРЕНЬ(E2))/(2*B2);ЕСЛИ(E2=0;-(B3)/(2*B2); «корней нет»)) Для X2: =ЕСЛИ(E2>0;(-B3+КОРЕНЬ(E2))/(2*B2);ЕСЛИ(E2=0;-(B3)/(2*B2); «корней нет»))
Решение квадратного уравнения x2-2x+1=0
Решение уравнения х2-5х+6=0.
2.3 Нахождение корней квадратного уравнения с помощью
средства «Поиск решения»
Команда Подбор параметра является удобной для решения задач поиска определенного целевого значения, зависящего от одного неизвестного параметра. Для более сложных задач следует использовать команду Поиск решения (Решатель), доступ к которой реализован через пункт меню Сервис/Поиск решения.
Рассмотрим, как воспользоваться Поиском решения на примере того же квадратного уравнения.
После открытия диалога Поиск решения (рис.9) необходимо выполнить следующие действия:
1) в поле Установить целевую ячейку ввести адрес ячейки, содержащей
формулу для вычисления значений оптимизируемой функции, в нашем примере целевая ячейка – это С4, а
формула в ней имеет вид: = C3^2 — 5*C3 + 6;
2) для максимизации значения целевой ячейки, установить переключатель максимальному значению в положение , для минимизации используется переключатель минимальному значению, в нашем случае устанавливаем переключатель в положение значению и вводим значение 0;
3) в поле Изменяя ячейки ввести адреса изменяемых ячеек, т. е. аргументов целевой функции (С3), разделяя их знаком «;» (или щелкая
мышью при нажатой клавише Сtrl на соответствующих ячейках),
для автоматического поиска всех влияющих на решение ячеек используется кнопка Предположить;
4) в поле Ограничения с помощью кнопки Добавить ввести все ограничения, которым должен отвечать результат поиска: для нашего примера ограничений задавать не нужно;
5) для запуска процесса поиска решения нажать кнопку Выполнить.
🔥 Видео
0.Блок схема. 8 классСкачать
5 способов решения квадратного уравнения ➜ Как решать квадратные уравнения?Скачать
Как разобраться в корнях ? Квадратный корень 8 класс | Математика TutorOnlineСкачать
Формула корней квадратного уравнения. Алгебра, 8 классСкачать
Самый подробный урок про Блок-схемы, Понимание, Чтение и Создание блок-схемСкачать
Комплексные корни квадратного уравненияСкачать
Решение биквадратных уравнений. 8 класс.Скачать
Решение квадратного уравнения с выводом формулы корнейСкачать
Нахождение корней квадратного уравненияСкачать
Составьте квадратное уравнение, корнями которого являются числаСкачать
Алгоритм решения квадратного уравненияСкачать
Быстрый способ решения квадратного уравненияСкачать
Решение задач с помощью квадратных уравнений. Алгебра, 8 классСкачать
основы программирования 6 алгоритмы и блок схемыСкачать
Программа для решения корней квадратного уравнения с использованием дискриминанта на языке ПаскальСкачать
Программа, определяющая корни квадратного уравнения. Язык программирования Python.Скачать
Метод выделения полного квадрата. 8 класс.Скачать
Решаем задачи в виде блок-схемы (7 класс)Скачать