Задача к ЕГЭ по информатике на тему «Поиск мест на поле (билеты, саженцы, матрицы)» №1

Задание выполняется с использованием прилагаемых файлов

При проведении эксперимента заряженные частицы попадают на чувствительный экран, представляющий из себя матрицу размером 10000  на 10000  точек. При попадании каждой частицы на экран в протоколе фиксируются координаты попадания: номер ряда (целое число от 1  до 10000  ) и номер позиции в ряду (целое число от 1  до 10000  ).

Точка экрана, в которую попала хотя бы одна частица, считается светлой, точка, в которую ни одна частица не попала, — тёмной.

При анализе результатов эксперимента рассматривают группы светлых точек, расположенных в одном ряду подряд, то есть без тёмных точек между ними.

Вам необходимо по заданному протоколу определить максимальную длину такой группы и номер ряда, в котором эта группа встречается. Если таких рядов несколько, укажите минимально возможный номер.

Входные данные:

Первая строка входного файла содержит целое число N  — общее количество частиц, попавших на экран. Каждая из следующих N  строк содержит 2  целых числа: номер ряда и номер позиции в ряду.

В ответе запишите два целых числа: сначала максимальную длину непрерывной группы светлых точек, затем – номер ряда, в котором эта группа встречается.

Пример входного файла:

7

1 2

2 3

3 6

2 4

1 3

2 5

2 4

При таких исходных данных имеется три группы светлых точек: в позициях 2− 3  ряда 1  , в позициях 3 − 5  ряда 2  и в позиции 6  ряда 3  . Самая длинная группа длины 3  находится во 2  ряду. Ответ: 3 2  .

Решение 1 (Excel/LibreOffice)
Откроем текстовый документ, скопируем значения и перенесем их в Excel или LibreOffice.
Воспользуемся настраиваемой сортировкой, на первый уровень расположим столбец A  (по возрастанию), на второй — столбец B  (по возрастанию). Выделим полностью столбцы A и B , перейдём в раздел «Данные»и нажимаем на инструмент «Удалить дубликаты в появившемся окне выбираем «Выделить все»и нажимаем «ОК»(это удалит частицы, которые были по ошибке сняты дважды). В ячейку C1  запишем 1  , а в C2  — формулу =ЕСЛИ(И(A2=A1;B2-1=B1);C1+1;1), скопируем её на все свободные клеточки этого столбца. Находим максимальную длину группы точек в столбце C  и номер ряда, в котором эта группа встречается. Выписываем этот номер и наименьший номер ряда, где нашлись обозначенные в задаче точки.

Решение 2 (Python)

f = open(’Задание_26__lood__rjlq.txt’)
n = int(f.readline())
a = [[0] * 10001 for j in range(10001)] # создаём пустую матрицу
maxim = 0 # максимальная длина
row = 0 # ряд
for i in range(n):
    x, y = [int(s) for s in f.readline().split()] # считывание текущей строки
    a[x][y] = 1 # помечаем, что данный пиксель на матрице занят
for i in range(10001):
    counter = 0 # счётчик подряд идущих светлых точек в ряду
    for j in range(10001):
        if a[i][j] == 1:
            counter += 1
        else:
            counter = 0
        if counter > maxim: # если счётчик больше максимума
            maxim = counter # перезаписываем максимум
            row = i # записываем ряд
print(maxim, row)

Ответ: 2 29
Оцените статью
Я решу все!