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

Задача о Санта-Клаусе и подарках

06.12.2019, 08:48. Показов 3749. Ответов 8

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, что не так с программой, все тестовые решения она проходит.
Задача:
Каждый год Санта-Клаус тайком пробирается в квартиры и дома, чтобы подкинуть хорошим детишкам подарки через дымовую трубу. Бывает, что коробки с подарками настолько большие, что никак в трубу не помещаются: у Санты уже случалось такое с игрушечными машинами, куклами в человеческий рост и наборами Лего.

Итак, у Санта-Клауса есть подарок размером AxBxC см, а внутренний размер дымовой трубы — DxE см. Определите, влезет ли такой подарок в трубу.

Размеры подарка и трубы по каждому измерению — целые числа от 1 до 100.

Напишите программу, которая принимает на вход две строки\\
A B C\\
D E\\
где DxE — внутренний размер трубы, AxBxC — размеры подарка.

На выходе — Yes, если подарок влезает в трубу, и No, если нет.

Примеры
10 10 10\\
10 10\\
\\
Yes

1 13 20\\
10 10\\
\\
Yes

1 14 20\\
11 10\\
\\
No

В поле ввода вставьте код программы. Чтение происходит из стандартного ввода или из файла input.txt, запись — в стандартный вывод или в файл output.txt. Мы рекомендуем использовать наиболее популярные языки программирования: Java, C++, Python, но на всякий случай включили и другие компиляторы.

Код:

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
len_p, widh_p, hei_p = map(int, input().split())
len_tr, wid_tr = map(int, input().split())
 
if len_p <= widh_p and len_p <= hei_p:
    dlina_p = len_p
    if widh_p <= hei_p:
        shirina_p = widh_p
    else:
        shirina_p = hei_p
 
elif widh_p <= len_p and widh_p <= hei_p:
    dlina_p = widh_p
    if len_p <= hei_p:
        shirina_p = len_p
    else:
        shirina_p = hei_p
 
elif hei_p <= len_p and hei_p <= widh_p:
    dlina_p = hei_p
    if len_p <= widh_p:
        shirina_p = len_p
    else:
        shirina_p = widh_p
 
t = max(dlina_p, shirina_p)
Dlina_p = min(dlina_p, shirina_p)
Shirina_p = t
 
t = max(len_tr, wid_tr)
Dlina_tr = min(len_tr, wid_tr)
Shirina_tr = t
 
 
if (Dlina_p <= Dlina_tr and Shirina_p <= Shirina_tr or 
   (Shirina_tr**2+Dlina_tr**2)**0.5 - (Shirina_p**2 + Dlina_p**2)**0.5 >= Dlina_p):
    print("Yes")
else:
    print("No")
Заранее спасибо!

Добавлено через 27 минут
Работает, если подставить это непонятное условие:

Python
1
2
3
4
5
6
7
8
if Dlina_p <= Dlina_tr and Shirina_p <= Shirina_tr:
    print("Yes")
elif Dlina_tr**2 >= Dlina_p**2 + Shirina_p**2:
    print("No")
elif(Dlina_tr*Shirina_tr>2*Dlina_p*Shirina_p) and ((Dlina_p**2 + Shirina_p**2 - Dlina_tr**2)*(Dlina_p**2 + Shirina_p**2 - Shirina_tr**2)<=((Dlina_tr**2)*(Shirina_tr**2) - 4 * Dlina_tr*Shirina_tr*Dlina_p*Shirina_p + 4 * (Dlina_p**2)*(Shirina_p**2))):
    print("Yes")
else:
    print("No")
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.12.2019, 08:48
Ответы с готовыми решениями:

Задача ”Тайный Санта"
Скоро Новый Год и студенты решили сыграть в Тайного Санту. Студент Арман подготовил по настоящему волшебный подарок. Это была шляпа, в...

Поиск в файле информации о подарках
Можете пожалуйста помочь сделать всё задание? Очень нужно :((( Есть текстовый файл &quot;Presents&quot; (с названиями подарков и...

Санта клаус
Однажды Санта Клаус, застряв в трубе дымохода, решил подтянуть свою физическую форму. Для этого он придумал такой план: в первый день он...

8
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,707
Записей в блоге: 14
06.12.2019, 10:09
Всего-то:

Python
1
2
3
4
5
6
7
8
9
def santa():
    [d1,d2,d3]=sorted(list(map(int,input().split(' '))))
    [g1,g2]=sorted(list(map(int,input().split(' '))))
    if (g1<=d1) and (g2<=d2):
        print("Yes")
    else:
        print("NO")
        
santa()
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
06.12.2019, 10:16
Catstail, ай ай ай)
DaniSSImo5, пояснения ко второму примеру.
Миниатюры
Задача о Санта-Клаусе и подарках  
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,707
Записей в блоге: 14
06.12.2019, 10:32
eaa, да, поторопился...

Добавлено через 8 минут
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
import math
 
def santa():
    d=list(map(int,input().split(' ')))
    g=list(map(int,input().split(' ')))
    g=g+[math.sqrt(g[0]**2+g[1]**2)]
    maxg=max(g)
    mind=min(d)
    if maxg<=mind:
        print("YES")
    else:
        print("NO")
 
santa()
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
06.12.2019, 10:40
Catstail,
2 11 20
10 10
Yes or No?)
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,707
Записей в блоге: 14
06.12.2019, 11:08
Опять-таки я неправ. Простой критерий, похоже, не "вытанцовывается". Попробую поискать...
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
06.12.2019, 11:26
Гипотенузы, катеты, теорема Пифагора. ТС думаю уже справится. На олимпиадную задачу похоже.
1
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38173 / 21108 / 4307
Регистрация: 12.02.2012
Сообщений: 34,707
Записей в блоге: 14
06.12.2019, 11:36
Хотелось бы короткое решение получить.

Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
import math
 
def santa():
    d=sorted(list(map(int,input().split(' ')))) 
    g=sorted(list(map(int,input().split(' '))))
    diag=math.sqrt(g[0]**2+g[1]**2)
    if d[1]<diag:
        delta=(diag-d[1])*0.5
        if (0.5*d[0])/delta < g[1]/g[0]:
            print("YES")
        else:
            print("NO")
        return
    else:
        print("NO")
 
santa()
0
0 / 0 / 0
Регистрация: 10.06.2017
Сообщений: 15
06.12.2019, 17:29  [ТС]
Да, я же приписал, что решено. Просто непонятно, почему первый код тесты не проходил: на тренировочных данных то всё хорошо было.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.12.2019, 17:29
Помогаю со студенческими работами здесь

Тайный Санта
В школе перед Новым годом устраивают игру в Тайного Санту. Каждому ученику i выдается ученик a(i), которому он должен подарить подарок. ...

Санта Клаус
Однажды Санта Клаус, застряв в трубе дымохода, решил подтянуть свою физическую форму. Для этого он придумал такой план: в первый день он...

Может ли Санта спасти Рождество?
О нет! Маленькие эльфы Санты в этом году болеют. Он должен сам раздавать подарки. Но у него осталось всего 24 часа. Он сможет это...

Задачки - погодная машина Санта-Клауса!
Может, кто-то уже слышал/делал задачки с http://adventofcode.com/ Как по мне, так они достаточно хороши, чтобы начать знакомиться с...

Возможен ли такой взлом? (Санта-Барбара по-русски)
Мой бывший молодой человек настраивал мне подключение ADSL и еще сделал такую вещь, что с его компа можно подключиться к моему и шарить там...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru