Я написал подобное приложение для планирования, и в итоге я выбрал немного другой подход (хотя ваш подход, безусловно, будет работать).
В этой системе расписание разбивалось на 15-минутные приращения, называлось блоками и сохранялось в таблице. Все были всегда доступны, если они специально не просили выходного. Эти запросы на отключение были сохранены в отдельной таблице, опять-таки с шагом 15 минут.
У нас была таблица ScheduleBlock, в которой в основном хранились все потенциальные блоки, заполненные на основе бизнес-правил, и таблица ScheduleException, в которой хранились блоки, которые пользователи не могли работать.
С этой структурой таблицы было легко создать пользовательский интерфейс, который отображал бы все объекты ScheduleBlock (это все потенциальное доступное время, т.е. рабочие часы), а затем дополнительно связывал все объекты ScheduleException (встречи, PTO). , больничные дни и т. д.), чтобы показать время, когда пользователи не могли работать (цветовая маркировка для каждого пользователя). Оттуда пользователь системы может выбирать блоки времени, которые он хотел запланировать для своего конкретного события, подобно тому, как работает MS Outlook.
Когда мы делали автоматическое планирование, как в вашем случае, мы запрашивали пользователей, у которых есть номер блока X, доступный для указанного диапазона дат, сортировали по количеству встреч, которые они имели, и просматривали их в поисках совпадения. Мы отсортировали по количеству встреч, чтобы человек с наиболее открытым расписанием был назначен первым.
Надеюсь, это поможет!