Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
38 / 38 / 0
Регистрация: 08.10.2013
Сообщений: 123
Записей в блоге: 1

Сравнение двух диапазонов значений на перекрытие

06.01.2014, 01:36. Показов 1696. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Приветствую всех!

Недавно столкнулся с интересной практической задачей и быстро понял, в ее основе должно быть какое-то очень простое решение.

Практическая задача: при создании записи (бронирование какого-то объекта на определенное время) тригер должен проверять два поля данной записи - начало бронирование и его конец - с такими же полями всех других записей бронирование данного объекта. Согласитесь - достаточно типовая практическая задача.

Как я понимаю все можно просто свести к сравнению двух диапазонов значение и не допускать их частичного или полного перекрытия.

Что есть поля (переменные) со временем начала и конца бронирования? если привести его к типу ДатаВремя - это будет просто огромное число миллисекунд. Таким образом в упрошенном виде можно написать, что мы пытаемся забронировать время диапазона с 1000 до 1010 и теперь нужно в цикле сравнить другие диапазоны на перекрытие (например уже существующая запись имеет диапазон 1005 - 1200, т.е. получается недопустимое перекрытие времени бронирования). Я чувствую, что это задача решается просто, очень просто, но я не могу додуматься как.

У вас есть идеи? Спасибо
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.01.2014, 01:36
Ответы с готовыми решениями:

Сравнение двух диапазонов на несовпадение
Подскажите пожалуйста, как организовать поиск на несовпадение? На первом листе таблицу надо сравнить с таблицей на втором листе. Если...

Сравнение диапазонов значений на разных листах
Здравствуйте, помогите сравнить 4 столбца, желательно формулой если можно. Есть два столбца "имя" и "фамилия" на...

Сравнение двух диапазонов по последней строке
Здравствуйте, Проблема такова. Необходимо сравнить значения в последних строках двух диапазонов, находящихся на одной странице....

6
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
06.01.2014, 01:55
Den Brown,
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
class Program
{
    static void Main(string[] args)
    {
        Interval[] array = new Interval[10];
        //здесь заполняете массив
        Interval New = new Interval(){Start = new DateTime(2014,1,5,16,0,0),
            End = new DateTime(2014,1,5,18,0,0)};
        if (array.Any(New.Includes))
            throw new Exception("Конфликт событий");
    }
}
class Interval
{
    public DateTime Start { get; set; }
    public DateTime End { get; set; }
    public bool Includes(Interval t)
    {
        return t.Start > Start && t.Start < End ||
            t.End < End && t.End > Start;
    }
}
Добавлено через 18 секунд
нужны System и Linq
1
38 / 38 / 0
Регистрация: 08.10.2013
Сообщений: 123
Записей в блоге: 1
06.01.2014, 01:59  [ТС]
Я на Salesforce and Apex, но начинал с .net.
на этом форуме податься мне не куда, поэтому запостил сюда.

получается, что все что мне нужно
C#
1
t.Start > Start && t.Start < End ||t.End < End && t.End > Start;
!!!

сейчас буду пробовать, спасибо
0
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
06.01.2014, 02:07
Цитата Сообщение от Den Brown Посмотреть сообщение
получается, что все что мне нужно
t.Start > Start && t.Start < End ||t.End < End && t.End > Start;
да, только у меня с булевой математикой как раз не очень. 100% будет работать правильно, если добавить скобки вот так
C#
1
(t.Start > Start && t.Start < End) || (t.End < End && t.End > Start);
0
38 / 38 / 0
Регистрация: 08.10.2013
Сообщений: 123
Записей в блоге: 1
06.01.2014, 02:16  [ТС]
утром все проверю в работе. Спасибо

Добавлено через 7 минут
нарисовал схему и кажется нашел ошибку.

формула выше - это:

есть ли перекрытие?

да есть, так как новое начало попало в диапазон существующей записи

или

да есть, так как новый конец попал в диапазон существующей записи.

А что если они не попадают, но есть событие начинается раньше и при этом заканчиваться позже. Попадание в диапазон как такого нет, есть его перекрытие
1
foo();
 Аватар для rattrapper
886 / 587 / 222
Регистрация: 03.07.2013
Сообщений: 1,549
Записей в блоге: 2
06.01.2014, 02:19
C#
1
(t.Start > Start && t.Start < End) || (t.End < End && t.End > Start) || (t.Start<Start && t.End>End);
Добавлено через 27 секунд
ну короче Вы уже не хуже меня шарите
1
38 / 38 / 0
Регистрация: 08.10.2013
Сообщений: 123
Записей в блоге: 1
06.01.2014, 02:24  [ТС]
а вот это, похоже, то что надо.

соображаю я хуже, просто думал на задачей и нарисовал схему: три столбика, слева направо - это ход времени, средний столбик - это уже существующее события. И теперь рисую на ней ситуации - сразу все видно, спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.01.2014, 02:24
Помогаю со студенческими работами здесь

Сравнение двух диапазонов ячеек на совпадение
Здравствуйте! Подскажите пожалуйста... Имеется 2 диапазона ячеек А1:A3 и C1:C3, в которых забиты цифры, допустим в ячейках А1:A3 (3,6,2...

Сравнение двух диапазонов и вывод различий на другой лист
Добрый день уважаемые форумчане! Нашёл в инете такой вот код: Option Explicit Sub compare() Dim a, b, c, t$, i&amp;,...

Сравнение двух диапазонов на идентичность без анализа отдельных ячеек
Здравствуйте! Подскажите, как сравнить два диапазона на результат ЛОЖЬ или ИСТИНА (в коде 10-я строка) Нужно это для проверки успешного...

Макрос для вставки значений из двух именованных диапазонов
Доброго времени суток! Помогите пожалуйста вот с каким вопросом полному лошарику в макросах. Имеется табель учета рабочего...

Разбить отрезок на 5 диапазонов значений по росту и подсчитать частоту попаданий элементов массива в каждой из этих диапазонов
Задание:1. Дано натуральное число N и одномерный массив A1, A2, ..., AN целых чисел. Определить наибольшее и наименьшее значения,...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru