Дан целочисленный массив из 30 элементов. Элементы массива могут
принимать целые значения от 0 до 100 – баллы учащихся выпускного
класса за итоговый тест по информатике. Для получения положительной
оценки за тест требовалось набрать не менее 20 баллов.
Опишите на
русском языке или на одном из языков программирования алгоритм,
который позволяет найти и вывести минимальный балл среди учащихся,
получивших за тест положительную оценку. Известно, что в классе хотя
бы один учащийся получил за тест положительную оценку.
Исходные данные объявлены так, как показано ниже. Запрещается
использовать переменные, не описанные ниже, но разрешается не
использовать часть из них.
const
N=30;
var
a: array [1..N] of integer;
i, j, min: integer;
beginfor i:=1to N do readln(a[i]);
...
end.
В качестве ответа Вам необходимо привести фрагмент программы (или
описание алгоритма на естественном языке), который должен находиться
на месте многоточия. Вы можете записать решение также на другом языке
программирования (укажите название и используемую версию языка
программирования, например, Borland Pascal 7.0) или в виде блок-схемы.
В этом случае вы должны использовать те же самые исходные данные и
переменные, какие были предложены в условии (например, в образце,
записанном на естественном языке).
Показать разбор
Содержание верного ответа и указания по оцениванию
(допускаются иные формулировки ответа, не искажающие его смысла)
min:=100;
for i:=1to N doif (a[i]>=20) and (a[i]<min) then
min:=a[i];
writeln(min);
Критерии оценки
2 баллаПредложен правильный алгоритм, выдающий верное значение.
Допускается запись алгоритма на другом языке, использующая
аналогичные переменные. В случае, если язык программирования
использует типизированные переменные, описания переменных
должны быть аналогичны описаниям переменных на
естественном языке. Использование нетипизированных или
необъявленных переменных возможно только в случае, если это
допускается языком программирования, при этом количество
переменных и их идентификаторы должны соответствовать
условию задачи. В алгоритме, записанном на языке
программирования, допускается наличие отдельных
синтаксических ошибок, не искажающих замысла автора
программы.
1 баллВ любом варианте решения может присутствовать не более одной ошибки из числа следующих: 1. Не инициализируется или неверно инициализируется
переменная MIN (например, ей присваивается значение a[1]
или число меньшее 100). 2. В сравнении с 20 вместо знака «больше или равно»
используется знак «больше». 3. Отсутствует вывод ответа. 4. Используется переменная, не объявленная в разделе
описания переменных. 5. Не указано или неверно указано условие завершения цикла. 6. Индексная переменная в цикле не меняется (например, в
цикле while) или меняется неверно. 7. Неверно расставлены операторные скобки.
0 балловОшибок, перечисленных в п. 1–7, две или больше, или алгоритм
сформулирован неверно.