Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности

Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
19.03.2021, 23:12
|
|||
|---|---|---|---|
Грамотная структура данных для хранения периодов дат |
|||
|
#18+
Добрый день Уважаемые! У меня такая задача: Есть PHP приложение, которое запрашивает из БД несколько временных периодов типа: Код: php 1. 2. 3. 4. 5. И мне надо этот набор отрезков привести к какой-то структуре данных, для которой я мог-бы быстро делать проверку: Есть ли отрезок, в который попадает указанный день. * Делать запросами к БД не подойдёт, т.к. проверок много в каждой итерации скрипта, неправильно это дёргать в таком случае БД. * Всякие пересечения и прочее неважны. Так что тут их не надо рассматривать. Пока выдумал что-то типа такого: * Берём год начала отрезка ($Y). Для каждого такого года заводим Код: php 1. * Берём порядковый №дня в году, начала отрезка (типа 5 ферваля это 36-ой день в году), ($NFrom) * Берём порядковый №дня в году, конца отрезка (аналогично) ($NTo). Тут разные года начала и конца не рассматриваем. Это я учёл. * Формируем типа такого: Код: php 1. с последующим flip'ом для проверки по ключу массива. Есть ли более грамотное решение такой задачи? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
19.03.2021, 23:55
|
|||
|---|---|---|---|
|
|||
Грамотная структура данных для хранения периодов дат |
|||
|
#18+
kormot, Код: php 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 17. 18. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=23&mobile=1&tid=1459500]: |
0ms |
get settings: |
10ms |
get forum list: |
20ms |
check forum access: |
5ms |
check topic access: |
5ms |
track hit: |
91ms |
get topic data: |
12ms |
get forum data: |
3ms |
get page messages: |
50ms |
get tp. blocked users: |
2ms |
| others: | 255ms |
| total: | 453ms |

| 0 / 0 |
