Напишите функцию Rectangle intersect(Rectangle r1, Rectangle r2), которая вернёт пересечение прямоугольников r1 и r2 — новый прямоугольник.
Если у прямоугольников r1 и r2 нет пересечения, то допускается в качестве результата работы функции вернуть любой неположительный по площади прямоугольник.
Используя функцию rectangle_square, описанную в предыдущей задаче, посчитайте площадь пересечения прямоугольников, вводимых с клавиатуры.
Формат входных данных
Даны координаты двух пар точек, заданных с точностью не более 2 знаков после десятичной точки. Координаты не превосходят по модулю 1000.
Последовательность чисел следующая:
- точка r1.p1: x и y
- точка r1.p2: x и y
- точка r2.p1: x и y
- точка r2.p2: x и y
Формат выходных данных
Требуется вывести одно вещественное число — площадь пересечения прямоугольников с точностью не менее 6 знаков после десятичной точки. Если прямоугольники не пересекаются, то выведите 0.
входные данные
4.0 6.0 3.0 9.0
1.0 4.0 5.0 8.0
выходные данные
2.000000
#include <iostream> //подключаем библиотеки
using namespace std; //пространство имён
int main() {
setlocale(LC_ALL, "Russian");
int tableInt; //последовательность
int x; //икс :)
bool ZaB = true; //бул для красоты
cout << "Введите переменную X: "; cin >> x; //просим X
cout << "Введите последовательность через пробел: "; //последовательность
while(cin >> tableInt) //цикл
{
if(ZaB) //для красоты
{
cout << "Результат: ";
ZaB = false;
}
if(tableInt != 0 && tableInt > x) //вывод того, что больше
{
cout << tableInt << " "; //если ноль, то конец!
}else if(tableInt == 0)
{
break;
}
}
return 0; //возращаем ничего
}
javascript:
var массив = [], n = prompt("n:"), m = prompt("m:");
for (let сч1 = 0; сч1 < n; сч1++) {
массив.push();
for (let сч2 = 0; сч2 < m; сч2++)
массив[сч1] = (function (от, до) { return Math.round(от - 0.5 + Math.random() * (до - от + 1)); })(1, 999);
}
var разрядов = [0, 0, 0], с_одинаковыми = 0;
for (let сч = 0; сч < n; сч++)
массив[сч].forEach(function (зн) {
разрядов[зн < 10 ? 0 : разрядов < 100 ? 1 : 2]++;
let разр = [зн / 100 | 0, зн / 10 % 10, зн % 10];
if (разр[0] == разр[1] || разр[0] == разр[2] || разр[1] == разр[2])
с_одинаковыми++;
});
alert(разрядов + " " + с_одинаковыми);