Задание 1
На первой картинке мы имеем 3 прямые, образующие треугольник. По точкам определим их функции.
Вершины треугольника: (1; 4), (5; -4), (-5; -3).
Функция прямой по двум точкам:
Подставляем точки и получаем три функции:
Точка находится в области, если y > l2(x0) И y < l1(x) И y < l3(x).
На Python это выглядит так. (Выводить функции не надо, это делается автоматически)
def get_line_by_two_points(x0: float, y0: float, x1: float, y1: float):
def line_y(x: float):
return (x - x0)/(x1 - x0) * (y1 - y0) + y0
return line_y
l1 = get_line_by_two_points(1, 4, 5, -4)
l2 = get_line_by_two_points(-5, -3, 5, -4)
l3 = get_line_by_two_points(1, 4, -5, -3)
x = int(input("Enter an X value: "))
y = int(input("Enter a Y value: "))
if y < l1(x) and y > l2(x) and y < l3(x):
print("Point is in the space!")
else:
print("Point is NOT in the space!")
Задание 2
Теперь у нас 4 прямые.
Мы имеем трапецию. Две прямые видны сразу: y = 1 и y = 7.
Оставшиеся две найдем по двум точкам автоматически.
Код на Python:
def get_line_by_two_points(x0: float, y0: float, x1: float, y1: float):
def line_y(x: float):
return (x - x0)/(x1 - x0) * (y1 - y0) + y0
return line_y
l1 = get_line_by_two_points(-3, 7, -6, 1) # Левая наклонная
l2 = get_line_by_two_points(7, 1, 4, 7) # Правая наклонная
x = int(input("Enter an X value: "))
y = int(input("Enter a Y value: "))
if 1 < y < 7 and y < l1(x) and y < l2(x):
print("Point is in the space!")
else:
print("Point is NOT in the space!")
===============================
Ваши оценки и отзывы лучше оценить качество решения.
Если ответ удовлетворил, не забудь выбрать его как "Лучший".
Успехов в учёбе!
Поделитесь своими знаниями, ответьте на вопрос:
Найти сумму всех чётных чисел от 6 до 102 и нарисовать алгоритм !
2) 97 / 2 = 48 (пар(ост.1(пусть это число 6)))
3) 7 + 102 = 109 (в паре)
4) 109 * 48 + 6 = 5238