СДАМ ГИА: РЕШУ ЕГЭ
Образовательный портал для подготовки к экзаменам
Информатика
≡ информатика
сайты - меню - вход - новости



Задания
Версия для печати и копирования в MS Word
Задание 24 № 7469

На обработку поступает последовательность из четырёх неотрицательных целых чисел (некоторые числа могут быть одинаковыми). Нужно написать программу, которая выводит на экран количество нечётных чисел в исходной последовательности и максимальное нечётное число. Если нечётных чисел нет, требуется на экран вывести «NO». Известно, что вводимые числа не превышают 1000. Программист написал программу неправильно. Ниже эта программа для Вашего удобства приведена на пяти языках программирования.

 

 

БейсикPython

CONST n = 4

count = 0

maximum = 999

FOR I = 1 TO n

INPUT x

IF x mod 2 <> 0 THEN

count = count + 1

IF x > maximum THEN

maximum = I

END IF

END IF

NEXT I

IF count > 0 THEN

PRINT count

PRINT maximum

ELSE

PRINT "NO"

END IF

n = 4

count = 0

maximum = 999

for i in range(1, n + 1):

    x = int(input())

    if x % 2 != 0:

        count += 1

        if x > maximum:

            maximum = i

if count > 0:

    print(count)

    print(maximum)

else:

    print("NO")

ПаскальАлгоритмический язык

const n = 4;

var i, x: integer;

var maximum, count: integer;

begin

count := 0;

maximum := 999;

for i := 1 to n do

begin

read(x);

if x mod 2 <> 0 then

begin

count := count + 1;

if x > maximum then

maximum := i

end

end;

if count > 0 then

begin

writeln(count);

writeln(maximum);

end

else

writeln('NO')

end.

алг

нач

цел n = 4

цел i, x

цел maximum, count

count := 0

maximum := 999

нц для i от 1 до n

ввод x

если mod(x, 2) <> 0 то

count := count + 1

если x > maximum то

maximum := i

все

все

кц

если count > 0 то

вывод count, нс

вывод maximum

иначе

вывод "NO"

все

кон

Си++

#include <iostream>

using namespace std;

int main(void)

{

const int n = 4;

int i, x, maximum, count;

count = 0;

maximum = 999;

for (i = 1; i <= n; i++) {

cin >> x;

if (x % 2 != 0) {

count++;

if (x > maximum)

maximum = i;

}

}

if (count > 0) {

cout << count;

cout << maximum;

}

else

cout << "NO\n";

}

 

 

Последовательно выполните следующее.

1. Напишите, что выведет эта программа при вводе последовательности: 2 9 4 3

2. Приведите пример такой последовательности, содержащей хотя бы одно нечётное число, что, несмотря на ошибки, программа печатает правильный ответ.

3. Найдите все ошибки в этой программе (их может быть одна или несколько). Известно, что каждая ошибка затрагивает только одну строку и может быть исправлена без изменения других строк. Для каждой ошибки:

 

1) выпишите строку, в которой сделана ошибка;

2) укажите, как исправить ошибку, т. е приведите правильный вариант строки.

 

 

Достаточно указать ошибки и способ их исправления для одного языка программирования. Обратите внимание, что требуется найти ошибки в имеющейся программе, а не написать свою, возможно, использующую другой алгоритм решения. Исправление ошибки должно затрагивать только строку, в которой находится ошибка.

Решение.

Решение использует запись программы на Паскале.

 

1. Программа выведет два числа: 2 и 999.

2. Пример последовательности, содержащей нечётные числа, для которой программа работает правильно: 1 2 3 999.

 

Замечание. В конце работы программы значение переменной maximum всегда равно 999. Соответственно, программа будет работать верно, если в последовательности есть 999. Выведенное количество нечётных чисел будет правильным в любом случае.

3. В программе есть две ошибки.

Первая ошибка: неверная инициализация maximum.

Строка с ошибкой:

maximum := 999;

Верное исправление:

maximum := 0;

Вместо 0 может быть использовано любое число, меньшее или равное 1.

Вторая ошибка: неверное присваивание при вычислении максимума.

Строка с ошибкой:

maximum = i;

Верное исправление:

maximum = x;

Источник: Де­мон­стра­ци­он­ная версия ЕГЭ—2015 по информатике.
Спрятать решение · ·
Алексей Ватолин 07.01.2015 21:13

Здравствуйте!

 

В программу на языке Python закралась весьма коварная ошибка. Функция input() считывает символы до пробела, как ожидали составители задачи, а сразу всю строку. В дальнейшем ее строку пытаются преобразовать в число и выскакивает ValueError. Не думаю, что в первом пункте задачи составители ожидали, что ученик вспомнит название ошибки и запишет ее. В Паскале например все хорошо, программа доходит до конца, но выводит неправильный ответ.

 

Методы исправления: пожалуй, исправить можно только довольно кардинально переписав программу, введя массив из 4 чисел и перебирая их в цикле. Но такое решения сделает ее непохожей на задачи на других языках программирования. Думаю, самым лучшим выходом будет убрать этот язык из предложенных в этой задаче или как-то изменить условие, чтобы обойти ошибку.

Служба поддержки

Число вводят через энтер, всё сработает правильно.