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

Ограничивающий прямоугольник

21.03.2018, 20:22. Показов 30674. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно написать класс BoundingRectangle, который обрабатывает точки на плоскости и строит по ним прямоугольник минимального размера, в который входят все эти точки. Если точка лежит на границе прямоугольника, считается, что она в него входит.

Нужно определить следующие методы (rect – экземпляр BoundingRectangle):

rect.add_point(x, y) — добавить новую точку.

rect.width() — ширина прямоугольника.

rect.height() — высота прямоугольника.

rect.bottom_y() — Y-координата нижней границы прямоугольника.

rect.top_y() — Y-координата верхней границы прямоугольника.

rect.left_x() — X-координата левой границы прямоугольника.

rect.right_x() — X-координата правой границы прямоугольника.

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

Формат ввода
Каждый тест представляет собой код, в котором будет использоваться ваш класс. Файл c решением не обязательно называть solution.py, он будет переименован автоматически. Тест запускается с вашим классом, а его вывод сравнивается с правильным решением.

Пример 1
Ввод Вывод

Python
1
2
3
4
5
6
7
8
from solution import BoundingRectangle
 
rect = BoundingRectangle()
rect.add_point(-1, -2)
rect.add_point(3, 4)
print(rect.left_x(), rect.right_x())
print(rect.bottom_y(), rect.top_y())
print(rect.width(), rect.height())
-1 3
-2 4
4 6
Пример 2
Ввод Вывод
Python
1
2
3
4
5
6
7
8
9
from solution import BoundingRectangle
 
rect = BoundingRectangle()
rect.add_point(10, 20)
rect.add_point(5, 7)
rect.add_point(6, 3)
print(rect.left_x(), rect.right_x())
print(rect.bottom_y(), rect.top_y())
print(rect.width(), rect.height())
5 10
3 20
5 17
Пример 3
Ввод Вывод
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
from solution import BoundingRectangle
 
rect = BoundingRectangle()
rect.add_point(-11, -12)
rect.add_point(13, -14)
rect.add_point(-15, 10)
print(rect.left_x(), rect.right_x())
print(rect.bottom_y(), rect.top_y())
print(rect.width(), rect.height())
print()
rect.add_point(-21, -12)
rect.add_point(13, -14)
rect.add_point(-15, 36)
print(rect.width(), rect.height())
print(rect.left_x(), rect.right_x())
print(rect.bottom_y(), rect.top_y())
print()
rect.add_point(-21, 78)
rect.add_point(13, -14)
rect.add_point(-55, 36)
print(rect.bottom_y(), rect.top_y())
print(rect.width(), rect.height())
print(rect.left_x(), rect.right_x())
print()
-15 13
-14 10
28 24

34 50
-21 13
-14 36

-14 78
68 92
-55 13
1
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
21.03.2018, 20:22
Ответы с готовыми решениями:

Дан прямоугольник n× m. Определите, какой прямоугольник
Дан прямоугольник n× m. Определите, какой прямоугольник от него нужно отрезать, чтобы получился квадрат. Считайте два целых числа: n и...

Ограничивающий прямоугольник
Получение ограничивающего прямоугольника для фигуры (см. типы из предыдущего пункта), стороны ограничивающего прямоугольника всегда...

Индексатор ограничивающий диапазон от -20 до 20
Как сделать индексатор ограничивающий диапазон от -20 до 20 в одномерном массиве целых числе? class DemoArray { private...

3
13 / 11 / 2
Регистрация: 14.01.2020
Сообщений: 5
18.03.2020, 09:33
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
class BoundingRectangle:
    def __init__(self):
        self.point_x = []
        self.point_y = []
 
    def add_point(self, x, y):
        self.point_x.append(x)
        self.point_y.append(y)
 
    def width(self):
        return max(self.point_x) - min(self.point_x)
 
    def height(self):
        return max(self.point_y) - min(self.point_y)
 
    def bottom_y(self):
        return min(self.point_y)
 
    def top_y(self):
        return max(self.point_y)
 
    def left_x(self):
        return min(self.point_x)
 
    def right_x(self):
        return max(self.point_x)
3
1 / 1 / 0
Регистрация: 17.03.2024
Сообщений: 2
17.03.2024, 10:45
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
class BoundingRectangle:
    def __init__(self):
        self.list_points = []
 
    def add_point(self, x, y):
        self.list_points.append((x, y))
 
    def width(self):
        return abs(max(self.list_points, key=lambda x: x[0])[0] - min(self.list_points, key=lambda x: x[0])[0])
 
    def height(self):
        return abs(max(self.list_points, key=lambda x: x[1])[1] - min(self.list_points, key=lambda x: x[1])[1])
 
    def bottom_y(self):
        return min(self.list_points, key=lambda x: x[1])[1]
 
    def top_y(self):
        return max(self.list_points, key=lambda x: x[1])[1]
 
    def left_x(self):
        return min(self.list_points, key=lambda x: x[0])[0]
 
    def right_x(self):
        return max(self.list_points, key=lambda x: x[0])[0]
0
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
17.03.2024, 11:37
Ну или так:
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
from math import inf
 
class BoundingRectangle:
    def __init__(self):
        self.top = -inf
        self.bottom = inf
        self.left = inf
        self.right = -inf
 
    def add_point(self, x, y):
        self.top = max(self.top, y)
        self.bottom = min(self.bottom, y)
        self.left = min(self.left, x)
        self.right = max(self.right, x)
 
    def width(self):
        return self.right - self.left
 
    def height(self):
        return self.top - self.bottom
 
    def bottom_y(self):
        return self.bottom
 
    def top_y(self):
        return self.top
 
    def left_x(self):
        return self.left
 
    def right_x(self):
        return self.right
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.03.2024, 11:37
Помогаю со студенческими работами здесь

Минифильтр, ограничивающий права доступа
Добрый день! Требуется написать минифильтр, ограничивающий права доступа к определённым файлам (например, чтобы заданный файл нельзя было...

Родительский контроль, ограничивающий работу определенных приложений
Задумал написать для себя программу по типу Родительского контроля, ограничивающую работу конкретных приложений например по часу... и сразу...

Определить обработчик исключительной ситуации, ограничивающий объем одноразового выделение динамической памяти
Вот наткнулся я на такого рода задание (Определить обработчик исключительной ситуации, ограничивающий объем одноразового выделение...

Для класса Прямоугольник создать класс наследник Прямоугольник со скругленными углами
Здравствуйте. Помогите, пожалуйста, выполнить задание. Необходимо создать класс Прямоугольник, с заданными длинами двух сторон(a b)....

Написать класс прямоугольник и построить прямоугольник, пересечением двух других
Помогите пожалуйста с задание до делать, нужно построить треугольник являющегося общей частью (пересечением) двух прямоугольников. У меня...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru