Разветвляющиеся алгоритмы. Блок-схема ветвления на Паскале. Пример программы, реализующей ветвление.
ИНФОРМАТИКА
Понятие алгоритма. Свойства алгоритма. Структура простейшей программы на Паскале. Вывод текста на экран.
Алгоритм– конечная последовательность действий, ведущая к определенному результату.
Свойства алгоритма:
- Дискретность (состоит из определенных шагов)
- Понятность (должен включать только команды, известные исполнителю)
- Определенность
- Конечность
- Массовость
- Корректность
Простейшая программа:
Program qq;
Begin [начало программы];
End.
Вывод текста на экран:
Program qq;
Begin
Write (‘2+’);
Writeln (2=?’);
Write (‘Ответ=4’);
End.
Переменные. Типы переменных. Объявление переменных в Паскале. Оператор присваивания.
Переменная – величина, имеющая имя, тип и значение.
Типы переменных:integer (целая), real (вещественная), double (двойной точности), char (символьный тип), string (строковый тип)
Объявления переменных:var a,b,c: integer;
Присваивание:а:=5
Блок-схема линейного алгоритма. Ввод значений с клавиатуры в Паскале. Ввод значений двух переменных.
Блок-схема:
Блок «начало» ->
Блок «ввод» ->
Блок «процесс»->
Блок «вывод» ->
Блок «конец» ->
Ввод значения с клавиатуры:read (a,b);
Оператор вывода в Паскале. Сложение двух чисел.
Вывод:write (a);
Writeln (a); - запись с переносом на след. Строку
Writeln (‘Значение=’, c);
Сложение двух чисел:простая программа на сложение
Арифметические операции в Паскале. Приоритет операций. Вывод целых чисел.
Арифметические операции в Паскале.
1. Операции с дробными числами (обычные, как в математике).
- вычитание; + сложение; * умножение; / деление.
2. Операции с целыми числами.
- вычитание; + сложение; * умножение;
Деление представлено двумя операциями:
div - целая часть от деления, mod - остаток.
23 div 3 = 7 23 mod 3 = 2
9 div 4 = 2 9 mod 4 = 1
35 div 10 = 3 35 mod 10 = 5
3. Приоритет арифметических операций: вначале - умножение и деление ( /, div, mod). Затем - сложение и вычитание. Порядок выполнения действий - слева направо. В выражениях могут быть скобки, при этом вначале производятся вычисления в скобках.
Вывод вещественных чисел в Паскале.
В pascal вещественное число представляется определённым образом, а именно с помощью десятичного признака и указания степени. Давайте создадим новую программу и в ней пропишем три переменных вещественного типа, где две переменных будем считывать с клавиатуры, и третей переменной присвоим произведение двух вещественных чисел считанных с клавиатуры:
Program Real_Num;
Uses crt;
var num1, num2, res: Real;
Begin
Clrscr;
write('Введите два вещественных числа через пробел - ');
Readln(num1, num2);
res := num1 + num2;
write('Сумма двух вещественных чисел - ', res);
Readln;
End.
Теперь выполним нашу программу и попробуем ввести два вещественных числа, например - 2.3212 5.2313 - и не стоит забывать что числа нужно вводить с точкой, а не с запятой.
И после получим результат - 1.21428935600000E+001. До знака плюс идёт десятичный признак, а после степень. Но такая запись нам не удобна. Для изменения вида в pascal используется специальная запись:
Program Real_Num;
Uses crt;
var num1, num2, res: Real;
Begin
Clrscr;
write('Введите два вещественных числа через пробел - ');
Readln(num1, num2);
res := num1 * num2;
write('Произведение двух вещественных чисел - ', res:4:4);
Readln;
End.
В выводе переменной с произведением мы внесли некоторые изменения, а именно - после переменной res поставили двоеточие и кол-во знаков до запятой - у нас их четыре, потом поставили ещё двоеточие и кол-во знаков после запятой - у нас их столько же. Вот такая запись используется в pascal. Если знаков до запятой меньше чем мы указали, то при выводе результата он у нас сместиться на недостающее кол-во цифр в право, то есть до видимого результата будут стоять невидимые нули, которые будут сдвигать ответ вправо.
Разветвляющиеся алгоритмы. Блок-схема ветвления на Паскале. Пример программы, реализующей ветвление.
Разветвляющийся алгоритм:if <условие> then begin
(что делать, если условие верно)
end
else begin
( -//-)
end.
Блок-схема:начало
|
ввод a,b
|
max:=a
|
да-----------(b>a?)-----------нет
| |
| |
max:=b |
└----------вывод max------- -┘
Пример программы:
program qq;
var a, b, max: integer;
begin
writeln (‘Введите 2 числа’);
read (a,b);
max:=a;
if b>a then max:=b;
writeln (‘Наибольшее число= ‘, max);
end.