Форум программистов, компьютерный форум, киберфорум
Lisp
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/11: Рейтинг темы: голосов - 11, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 19.12.2012
Сообщений: 42

Найти пересечение всех отрезков

15.01.2013, 17:06. Показов 2394. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
дан список вещественных чисел (a1 b1 a2 b2....an bn), ai<bi. Рассматривая ai и bi, как левые и правые концы отрезков на одной и той же прямой, определить функцию, выдающую концы отрезка, являющегося пересечением всех этих отрезков. если такого отрезка нет, то выдать nil.

Коментарии к задачи:
нужно написать функции для нахождения (min b), (max a) и функцию которая проверяет входят они в один отрезок или нет, если да то выдать этот отрезок.

 Комментарий модератора 
Запрещено создавать темы с множеством вопросов во всех разделах, кроме разделов платных услуг. Один вопрос - одна тема.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
15.01.2013, 17:06
Ответы с готовыми решениями:

Определить функцию, возвращающую концы отрезка, являющегося пересеченияем всех отрезков
помогите пожалуйста с решением! дан список вещественных чисел (a1 b1 a2 b2....an bn), ai&lt;bi. Рассматривая ai и bi, как левые и...

Определить отрезок, полученный как пересечение всех указанных отрезков
Задача: Дан файл из чисел, где каждая пара - отрезок (например -1 3 0 9 6 24) Определить отрезок, полученный как...

Найти пересечение двух ОТРЕЗКОВ каждый из которых ограничен двумя точками
Написал подобную программу для нахождения пересечения прямых а для пересечения отрезков не понимаю как сделать.буду признателен если...

4
 Аватар для _sg
4709 / 4404 / 380
Регистрация: 12.05.2012
Сообщений: 3,101
15.01.2013, 17:36
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
(defun intercom (w)
  (when w (cons (loop for e from (car w) to (cadr w) collect e)
                (intercom (cddr w)))))
 
(defun intercom-section (w)
  (reduce #'intersection (intercom w)))
 
(defun intercom-section-marks (w &aux (v (intercom-section w)))
  (cons (car v) (last v)))
 
> (intercom-section-marks '(2 15 10 20 12 25))
(12 15)
0
0 / 0 / 0
Регистрация: 19.12.2012
Сообщений: 42
15.01.2013, 19:28  [ТС]
Это слишком сложно. надо написать так как в предыдущей задаче.
0
Эксперт функциональных языков программированияЭксперт Java
 Аватар для korvin_
4575 / 2774 / 491
Регистрация: 28.04.2012
Сообщений: 8,779
15.01.2013, 23:13
Lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
(defun find-min (min list)
  (cond ((null list) min)
        ((< (car list) min) (find-min (car list) (cddr list)))
        (t (find-min min (cddr list)))))
 
(defun find-max (max list)
  (cond ((null list) max)
        ((> (car list) max) (find-max (car list) (cddr list)))
        (t (find-max max (cddr list)))))
 
(defun find-max-a (list)
  (find-max (car list) (cddr list)))
 
(defun find-min-b (list)
  (find-min (cadr list) (cdddr list)))
 
(defun same-segment-p (a b list)
  (cond ((null list) nil)
        ((and (= a (car  list))
              (= b (cadr list)))
         (cons a b))
        (t (same-segment-p a b (cddr list)))))
Но это уродство и так лучше не писать =)
0
Супер-модератор
Эксперт функциональных языков программированияЭксперт Python
 Аватар для Catstail
38177 / 21112 / 4307
Регистрация: 12.02.2012
Сообщений: 34,716
Записей в блоге: 14
16.01.2013, 12:50
А так:

Lisp
1
2
3
4
5
6
7
8
9
10
11
12
(defun inters (lst)
  (let ((c 1) (amax (car lst)) (bmin (cadr lst)))
    (mapcar #'(lambda (x) (if (> c 0) (setq amax (max x amax))
                                      (setq bmin (min x bmin)))
                          (setq c (- c))) lst )
    (if (> bmin amax) (list amax bmin) nil)))
 
==> inters
 
(inters '(1 3 2 7))
 
==> (2 3)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
16.01.2013, 12:50
Помогаю со студенческими работами здесь

Пересечение отрезков.
Решал задачу на acmp про пересечение отрезков, завалился на 20 тесте. Долго просидел, решил прочитать комментарии. Объясните мне, если...

Пересечение 2 отрезков
Дано 2 отрезка, заданы координатами концов. Как выяснить, будут ли пересекаться прямые из них (если отрезки &quot;дополнить&quot; до...

пересечение 2-х отрезков
подскажите формулу по которой можно расчитать пересекаются 2 отрезка или нет

Пересечение отрезков
Как проверить пересечение отрезков? Т.е. координаты не нужны. Всё что делал - не работает когда один отрезок лежит на другом. Как...

Пересечение отрезков
Есть 2 отрезка, определенные O1(x1, y1, x2, y2) и O2(x1, y1, x2, y2) Нужно узнать, пересекаются ли они. Собственно задача не так...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью 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. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru