Найти количество квадратов, имеющих общую точку с прямой - C#

Узнай цену своей работы

Формулировка задачи:

В прямоугольной декартовой системе координат прямая задана двумя принадлежащими ей точками (О, W) и (100N, Е). Также заданы N2 квадратов со сторонами, параллельными осям координат. Квадрат Si,j имеет координаты углов (100i, 100j) и (100i - 100,100j - 100), i,j = 1,2,…N Требуется найти количество квадратов, имеющих общую точку с прямой. Ограничения: 1 < N< 100, 0 < W, Е< 100N, все числа целые. Ввод из файла sqline.in. В первой строке находятся три целых числа, N, Wи Е, разделенных пробелами. Вывод в файл sqline.out. Вывести одно число — количество квадратов. Нужно реализовать с помощью С++ или С# (си шарп)

Решение задачи: «Найти количество квадратов, имеющих общую точку с прямой»

textual
Листинг программы
  1. // Прямая AB которая должна проходить через квадраты
  2. double Ax = 0, Ay = 0, Bx = 1, By = 1;
  3.  
  4. // Прямоугольники
  5. double[][] squares =
  6. {
  7.     //{ x1, y1, x2, y2 }
  8.     new double[]{ 0, 0, 1, 1 },
  9.     new double[]{ 1, 0, 2, 1 },
  10.     new double[]{ 1.1, 0, 2, 1 }, // этот немного правее прямой
  11. };
  12.            
  13. // Угол наклона прямой
  14. double angle = -Math.Atan2(By - Ay, Bx - Ax);
  15.            
  16. // Вторая строка матрицы поворота
  17. double Rx = Math.Sin(angle), Ry = Math.Cos(angle);
  18.  
  19. // Сигнум с заданной точностью
  20. Func<double, int> Sgn = (x) => Math.Abs(x) < 1e-15 ? 0 : Math.Sign(x);
  21.  
  22. // Индикатор, того, что точка в новых координатах
  23. // Лежит выше оси Ox (или на ней)
  24. Func<double, double, int> I = (x, y) => Sgn(Rx * x + Ry * y);
  25.  
  26. // Вернет true если квадрат содержит часть прямой AB
  27. Func<double[], bool> Test = (s) =>
  28.     Math.Abs(I(s[0], s[1]) + I(s[0], s[3]) + I(s[2], s[1]) + I(s[2], s[3])) < 4;
  29.  
  30. Console.WriteLine(squares.Count(Test));
  31. Console.ReadLine();

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

6   голосов , оценка 4 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы