Тема 27. Программирование
27.03 Цепочки, выбор последовательности, префиксные суммы
Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела программирование
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#86276

Дана последовательность из N натуральных чисел. Рассматриваются все её непрерывные подпоследовательности, такие что сумма элементов каждой из них кратна максимальному числу из файла, которое находится в ряду Фибоначчи. Найдите среди них подпоследовательность с максимальной суммой, определите её длину. Если таких подпоследовательностей найдено несколько, в ответе укажите количество элементов самой короткой из них.

Входные данные: Даны два входных файла: файл A и файл B, каждый из которых содержит в первой строке количество чисел N (          8
2 ≤ N ≤ 10  ). Каждая из следующих N строк содержит натуральное число, не превышающее 10 000.

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

7

44

11

42

5

34

63

95

В этом наборе можно выбрать последовательность 44+11+42+5+34 (сумма 136), кратна 34 ( это число является максимальным из файла, которое при этом находится в ряду Фибоначчи). Длина этой подпоследовательности равна 5. Ответ: 5.

В ответе укажите два числа через пробел: сначала значение искомой длины для файла А, затем для файла B.

Вложения к задаче
Показать ответ и решение
Решение для А пункта:
f = open(’3_27A.txt’)
n = int(f.readline())
a = [int(i) for i in f]
max_a = max(a)

fibb = [0,1,1]
while fibb[-1] < max_a:
    fibb.append(fibb[-1] + fibb[-2])
D = max(x for x in set(a) if x in fibb)
mx = 0
l = 0
for i in range(len(a)):
    s = 0
    k = 0
    for j in range(i,len(a)):
        s += a[j]
        k += 1
        if s % D == 0:
            if s > mx or (s == mx and k < l):
                mx = s
                l = k
print(l)
Решение для Б пункта:
f = open(’3_27B.txt’)
n = int(f.readline())
a = [int(i) for i in f]
fibb = [0,1]
while fibb[-1] < max(a):
    fibb.append(fibb[-1] + fibb[-2])
D = max(x for x in set(a) if x in fibb)
mx = 0
l = 0
k = [10**20 for i in range(D)]
ml = [0 for i in range(D)]
s = 0
for i in range(n):
    x = a[i]
    s += x
    if s % D == 0:
        mx = s
        l = i + 1
    s1 = s - k[s % D]
                                                                                                  
                                                                                                  
    l1 = (i+1) - ml[s % D]
    if s1 > mx or (s1 == mx and l1 < l):
        mx = s1
        l = l1
    if s < k[s % D]:
        k[s % D] = s
        ml[s % D] = i + 1
print(l)

Ответ: 343 47816

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное обучение
в Школково

Для детей ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Брянской областей, а также школьникам, находящимся в пунктах временного размещения Крыма обучение на платформе бесплатное.

Налоговые вычеты

Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей

Бесплатный доступ к любому курсу подготовки к ЕГЭ или олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!