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

Ещё уравнение

06.05.2024, 13:27. Показов 605. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дано целое число N. Определите, существует ли пара натуральных чисел (A,B) такая, что 3^A+5^B=N и найдите одну такую пару, если она существует.

Формат входных данных
Дано одно целое число
N (1≤N≤10^18).

Формат результата
Если не существует пары (A,B), удовлетворяющей условию, выведите −1. Если такая пара существует, выведите A и B одной такой пары с пробелом между ними. Если таких пар несколько, будет принята любая из них.

Примеры
Входные данные
106
Результат работы
4 2
Входные данные
1024
Результат работы
-1

Тема Линейный поиск в списках и матрицах
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.05.2024, 13:27
Ответы с готовыми решениями:

Как добавить еще программу для закрытия, чтобы закрывался не только firefox а еще yandex?
:start nircmd.exe win hide ititle "cmd.exe" @echo off set "p1=chrome.exe" set "p2=firefox.exe" cmd /c for /l %%# in () do...

Какими ещё способами можно ещё сделать?
Задание: Известно, что: 1 в третей степени будет=1 2 в третей степени будет=3+5 3 в третей степени будет=7+9+11 4 в третей...

Создать классы Уравнение, Линейное уравнение, Квадратное уравнение
. Корень уравнения, Линейное, Квадратное (класс для каждого) a. Описать объекты разных классов. С помощью переопределяемого метода...

7
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38200 / 21132 / 4310
Регистрация: 12.02.2012
Сообщений: 34,739
Записей в блоге: 14
06.05.2024, 15:29
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
n=int(input())
 
x3=[1]
p=3
while p<n:
    x3.append(p)
    p=p*3
 
x5=[1]
p=5
while p<n:
    x5.append(p)
    p=p*5
 
flag=False
for u,a in enumerate(x3):
    for v,b in enumerate(x5):
        if a+b==n:
            print(u,v)
            flag=True
            break
    if flag:
        break
if not flag:
    print(-1)
1
207 / 5 / 2
Регистрация: 27.04.2024
Сообщений: 72
06.05.2024, 15:36  [ТС]
Catstail, Благодарю за ответ, ваш код почти верен, он выводит неверный ответ в 15 тесте, а что за тест я не знаю. Всё равно благодарю за ответ.
0
Вирусоборец
 Аватар для thyrex
14450 / 7489 / 1582
Регистрация: 06.09.2009
Сообщений: 27,133
10.05.2024, 00:09
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
n = int(input())
if n%10 in [2, 4, 6, 8]: # 3**n может оканчиваться только на 1, 3, 7, 9, а 5**n всегда оканчивается на 5
    x3 = [1]
    p = 3
    while p<n:
        x3.append(p)
        p *= 3
    x5 = [1]
    p = 5
    while p<n:
        x5.append(p)
        p *= 5
    flag = False
    p = len(x5)-1
    while not flag and p != 0:
        if not ((n - x5[p]) in x3):
            p -= 1
        else:
            b = p
            a = x3.index(n - x5[p])
            flag = True
    if flag:
        print(a, b)
    else:
        print(-1)
else:
    print(-1)
1
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
10.05.2024, 03:39
Ну или так:
Python
1
2
3
4
5
6
from math import log
 
n = int(input('n = '))
_3_arr = [3**i for i in range(1, int(log(n,3)) + 2)]
_5_arr = [5**i for i in range(1, int(log(n,5)) + 2)]
print(*[(_3_arr.index(a)+1, _5_arr.index(b)+1) for a in _3_arr for b in _5_arr if a+b == n][0])
1
55 / 39 / 23
Регистрация: 07.05.2024
Сообщений: 58
10.05.2024, 16:37
Python
1
2
3
4
from itertools import product as p
 
pairs = {(3 ** a + 5 ** b): (a, b) for a, b in p(range(1, 38), repeat=2)}
print(*(lambda n: pairs[n] if n in pairs else [-1])(int(input())))
1
190 / 3 / 2
Регистрация: 08.05.2024
Сообщений: 24
10.05.2024, 16:53
contrlc, вы на этом курсе?
0
55 / 39 / 23
Регистрация: 07.05.2024
Сообщений: 58
10.05.2024, 16:55
anton7685, Нет
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
10.05.2024, 16:55
Помогаю со студенческими работами здесь

Как из input сделать <div>показать еще</div> или <a>показать еще</a>?
Таким скриптом я подгружаю данные. &lt;script&gt; $(document).ready(function(){ $('#show_more').click(function(){ ...

Составить уравнение параболы с вершиной в начале координат, если уравнение ее директрисы x = -5
66.Составить уравнение параболы с вершиной в начале координат, если уравнение ее директрисы x = -5

Подставить в уравнение такие десятичные цифры, чтобы уравнение стало верным
В уравнении вида A + B = C, где A, B и C — неотрицательные целые числа, некоторые цифры заменены на знаки вопроса. Необходимо...

Составить уравнение гиперболы, если известны её эксцентриситет, фокус и уравнение директрисы
Составить уравнение гиперболы, если известны её эксцентриситет e = sqrt(5), фокус (2;-3) и уравнение директрисы 2x-y+3=0. Долго...

Составить уравнение параболы с вершиной в начале координат, если уравнение ее директрисы x = -5
Составить уравнение параболы с вершиной в начале координат, если уравнение ее директрисы x = -5 .


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru