Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.96/256: Рейтинг темы: голосов - 256, средняя оценка - 4.96
2 / 2 / 0
Регистрация: 26.10.2022
Сообщений: 4

Лука наблюдает за кузнечиками

26.10.2022, 09:38. Показов 52490. Ответов 2

Студворк — интернет-сервис помощи студентам
Лука наблюдает за кузнечиками
Ограничение по времени: 1 секунда

Любимое занятие Луки — наблюдать за кузнечиками. Сегодня утром, прогуливаясь по парку, он обнаружил кузнечика, который прыгал по окружности длиной n метров. Лука заметил, что за один прыжок кузнечик может переместиться по часовой стрелке на k или k+1 метров от своей текущей позиции на окружности. Мальчику стало интересно, какое минимальное количество прыжков потребуется кузнечику, чтобы, начав прыгать из некоторой точки окружности, снова оказаться в ней.

Формат входных данных
Первая строка содержит одно целое число n (1≤n≤106) — длина окружности в метрах.
Вторая строка содержит одно целое число k (1≤k≤109) — характеристика длины прыжка кузнечика в метрах.
Гарантируется, что 1≤n⋅k≤109.

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

Система оценки
Решения, правильно работающие только для случаев, когда n не превосходит 100, будут оцениваться в 60 баллов.

Пояснение
Рассмотрим первый пример из условия. Один из вариантов действий кузнечика таков:

Выполнить прыжок длины 3,
Выполнить прыжок длины 4,
Выполнить прыжок длины 3.
Таким образом, суммарно кузнечик преодолеет 3+4+3=10 метров, то есть вернётся в исходную точку.
Во втором примере из условия кузнечику достаточно выполнить пять прыжков длины 2.
В третьем примере из условия можно выполнить один прыжок длины 8 и два прыжка длины 7. Таким образом, суммарно кузнечик преодолеет 8+7+7=22 метра, то есть обойдёт окружность дважды и вернётся в исходную точку.

Ввод Вывод
10 3
3

Ввод Вывод
10 5
1

Ввод Вывод
11 3
7
1
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.10.2022, 09:38
Ответы с готовыми решениями:

Чехарда с кузнечиками
Дорожка замощена плитками в один ряд, плитки пронумерованы числами от 1 до 1000. На плитках с номерами A, B и C (ABC) сидят три кузнечика,...

Проблемы с решением. Python. Чехарда с кузнечиками
День добрый. Вот уже 3-й день пытаюсь решить задачу, решил, но не до конца. Прошло 4/6 тестов, какие тесты-неизвестно/ Вот ее условие:...

Узнать за каким элементами наблюдает IntersectionObserver
Как в браузере можно узнать за какими элементами в данный момент наблюдает IntersectionObserver?

2
27 / 21 / 8
Регистрация: 14.12.2021
Сообщений: 36
26.10.2022, 10:18
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
import sys
 
def get():
    return sys.stdin.readline().strip()
 
def put(s):
    sys.stdout.write(s)
 
 
def calc(a, b, n):
    if a + b >= n:
        return a + b - n
    return a + b
 
 
def solve():
    n = int(get())
    k = int(get())
 
    used = [False] * n
    dist = [0] * n
 
    step1 = k % n
    step2 = (k + 1) % n
 
    used[step1] = True
    used[step2] = True
    
    q = [0] * (10*n)
    q[0] = step1
    q[1] = step2
 
 
    top = 0
    back = 2
 
    dist[step1] = 1
    dist[step2] = 1
    while not used[0]:
        node = q[top]
        top += 1
 
        if not used[calc(node, step1, n)]:
            used[calc(node, step1, n)] = True
            dist[calc(node, step1, n)] = dist[node] + 1
            q[back] = (calc(node, step1, n))
            back += 1
            
 
        if not used[calc(node, step2, n)]:
            used[calc(node, step2, n)] = True
            dist[calc(node, step2, n)] = dist[node] + 1
            q[back] = (calc(node, step2, n))
            back += 1
            
 
    put(str(dist[0]))
 
solve()
2
0 / 0 / 0
Регистрация: 13.05.2021
Сообщений: 1
26.10.2022, 15:52
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
import sys
 
def get():
    return sys.stdin.readline().strip()
 
def put(s):
    sys.stdout.write(s)
 
 
def calc(a, b, n):
    if a + b >= n:
        return a + b - n
    return a + b
 
 
def solve():
    n = int(get())
    k = int(get())
 
    used = [False] * n
    dist = [0] * n
 
    step1 = k % n
    step2 = (k + 1) % n
 
    used[step1] = True
    used[step2] = True
    
    q = [0] * (10*n)
    q[0] = step1
    q[1] = step2
 
 
    top = 0
    back = 2
 
    dist[step1] = 1
    dist[step2] = 1
    while not used[0]:
        node = q[top]
        top += 1
 
        if not used[calc(node, step1, n)]:
            used[calc(node, step1, n)] = True
            dist[calc(node, step1, n)] = dist[node] + 1
            q[back] = (calc(node, step1, n))
            back += 1
            
 
        if not used[calc(node, step2, n)]:
            used[calc(node, step2, n)] = True
            dist[calc(node, step2, n)] = dist[node] + 1
            q[back] = (calc(node, step2, n))
            back += 1
            
 
    put(str(dist[0]))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.10.2022, 15:52
Помогаю со студенческими работами здесь

Проблемы с решением. C++. Чехарда с кузнечиками
День добрый. Вот уже 3-й день пытаюсь решить задачу, решил, но не до конца. Прошло 4/6 тестов, какие тесты-неизвестно. Сам код на Python,...

Лука в кинотеатре
Ограничение по времени: 1 секунда Воскресным утром в кинотеатре в двух залах одновременно начался показ фильмов. Фильм, показываемый в...

Лука и массив
Лука и массив Ограничение по времени: 2 секунды У Луки есть массив из n целых чисел a1, a2, . . . , an. K каждому элементу массива...

Лука и массив
Лука и массив Ограничение по времени: 2 секунды У Луки есть массив из n целых чисел a1, a2, . . . , an. K каждому элементу массива...

Лука в кинотеатре
Лука в кинотеатре Ограничение по времени: 1 секунда Воскресным утром в кинотеатре в двух залах одновременно начался показ...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Киев стоит - украинская песня
zorxor 28.01.2026
wfWdiRqdTxc О Господи, Вечный, Ты . . . Я помоги, Бесконечный. . . Я прошу Ты. . . Я погибаю, спаси. . . Я прошу Тебя Вечный. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru