С Новым годом! Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/9: Рейтинг темы: голосов - 9, средняя оценка - 4.56
0 / 0 / 0
Регистрация: 29.03.2020
Сообщений: 5

Задача по олимпиадному программированию не проходит по времени

29.03.2020, 13:28. Показов 2020. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Problem C. What a sequence!
Input file: standard input
Output file: standard output
Time limit: 2 seconds
Memory limit: 512 mebibytes
Let an be a sequence defined by the recursive formula:
an+2 = k · an+1 + an
a0 = 0
a1 = 1
Given a certain k ∈ {1, 3, 5, 7} and an odd prime number p, your task is to find the value of ap mod p.
Input
In the first line one integer Z ≤ 106
is given, denoting number of testcases described in following lines.
For each test case, first and the only input line contains two natural numbers p and k, p being an odd
prime number.
k ∈ {1, 3, 5, 7}. The total length of the numbers p in the all testcases doesn’t exceed 106
.
Output
For each test case you should print exactly one line containing the value of ap mod p.

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


Python
1
2
3
4
5
6
7
8
9
10
11
a_0 = 0
a_1 = 1
for i in range(int(input())):
    p, k = map(int, input().split())
    for j in range(p - 1):
        a_new = k * a_1 + a_0
        a_0 = a_1
        a_1 = a_new
    print(a_new % p)
    a_0 = 0
    a_1 = 1
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.03.2020, 13:28
Ответы с готовыми решениями:

Задача по олимпиадному программированию
Помогите решить данную задачу Легенда: Гена участвует в закрытом бета-тестировании нового пазл-платформера. На очередном уровне...

Задача по олимпиадному программированию
Помогите решить задачу. Я имел идею перебирать все варианты, которое заходит только на 10%. Мост между островами Тысячи и тысячи лет...

Шарики(Задача по олимпиадному программированию)
Решение(не идеально,я знаю): #include <iostream> #include <stdio.h> #include <math.h> using namespace std; int main(){ ...

4
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
29.03.2020, 14:04
а какая разница какой язык? если алгоритм не правильный.
что вам с++ дай что питон, это ничего не изменит.
0
0 / 0 / 0
Регистрация: 29.03.2020
Сообщений: 5
29.03.2020, 15:36  [ТС]
в этом и проблема, что алгоритм вроде правильный, но времени тратит больше, чем надо...
0
Эксперт Python
5438 / 3859 / 1215
Регистрация: 28.10.2013
Сообщений: 9,552
Записей в блоге: 1
29.03.2020, 16:13
Лучший ответ Сообщение было отмечено supermegahaxer как решение

Решение

Цитата Сообщение от supermegahaxer Посмотреть сообщение
голова подсказывает, что без c++ не стоит даже соваться в олимпиадки, это так?
Нет. Туда не стоит соваться без наличия интеллекта и знаний.
Ваш код алгоритмически неоптимален, именно поэтому он очень долго работает.
А уповать на С++ ... боже какая детская наивность...
2
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
29.03.2020, 16:23
supermegahaxer, зачем вам памяти 512 Мб дают?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.03.2020, 16:23
Помогаю со студенческими работами здесь

Как научиться олимпиадному программированию
Что делать, если я уже более 5 лет пишу код в веб, c++, но, я не умею решать задачи из олимпиад? Какие сайты изучить?

Ищу людей для подготовки по олимпиадному программированию
Здравствуйте.Заранее прошу прощения у модераторов - я не знаю, куда эту тему выкладывать. Перенесите её, пожалуйста. В чём суть.Я...

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

Задача не проходит по времени
Доброго времени суток, есть вот такая задача: И мое решения: std::string toB(int n) { std::string ret = ""; while...

Задача не проходит по времени 2 теста
Решаю задачу на informatics(да, сириус...) Подсчитайте количество натуральных делителей числа x (включая 1 и само число; x<2*10**9 ). ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Модель микоризы: классовый агентный подход 3
anaschu 06.01.2026
aa0a7f55b50dd51c5ec569d2d10c54f6/ O1rJuneU_ls https:/ / vkvideo. ru/ video-115721503_456239114
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru