|
7 / 7 / 3
Регистрация: 15.01.2014
Сообщений: 459
|
||||||
Ускорение поиска в массиве13.10.2016, 00:41. Показов 2540. Ответов 9
Метки нет (Все метки)
Я написал отрывок кода, который по значению ключа ищет индекс массива, но работает эта вещь очень долго(2-3 секунды загружается страница). Есть какие-то идеи, как это дело можно переписать, чтобы увеличить скорость поиска?
0
|
||||||
| 13.10.2016, 00:41 | |
|
Ответы с готовыми решениями:
9
Скорость, касательное ускорение, полное ускорение, нормальное ускорение и радиус кривизны траектории Ускорение поиска данных Ускорение поиска в базе |
|
936 / 693 / 236
Регистрация: 01.02.2015
Сообщений: 1,848
|
|
| 13.10.2016, 00:50 | |
|
может array_search
0
|
|
|
7 / 7 / 3
Регистрация: 15.01.2014
Сообщений: 459
|
||||||
| 13.10.2016, 01:08 [ТС] | ||||||
|
Fedor Vlasenko, не будет работать. Мне нужно искать ключ массива рекурсивно, а array_search не даёт такой возможности. На сайте PHP есть функция рекурсивного поиска, но она работает не быстрее моей:
0
|
||||||
|
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
|
|
| 13.10.2016, 01:46 | |
|
0
|
|
|
7 / 7 / 3
Регистрация: 15.01.2014
Сообщений: 459
|
|
| 13.10.2016, 01:48 [ТС] | |
|
Jewbacabra, вы предлагаете что-то конкретное?
0
|
|
|
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
|
|
| 13.10.2016, 01:55 | |
|
0
|
|
|
7 / 7 / 3
Регистрация: 15.01.2014
Сообщений: 459
|
|||||||||||
| 13.10.2016, 02:07 [ТС] | |||||||||||
|
Jewbacabra, задача: есть json-файл с множеством подобных строк:
В моём случае, я декодирую json-строку в массив и использую метод рекурсивного поиска ключа массива:
0
|
|||||||||||
|
4925 / 3920 / 1620
Регистрация: 24.04.2014
Сообщений: 11,441
|
||
| 13.10.2016, 02:20 | ||
|
Чтобы ускорить нужно отказываться от json и хранить данные в бд. Тогда поиск будет намного быстрее и проще.
0
|
||
|
7 / 7 / 3
Регистрация: 15.01.2014
Сообщений: 459
|
|||||||||||
| 13.10.2016, 03:06 [ТС] | |||||||||||
|
Jewbacabra, я в замешательстве. Проверил функции поиска и функции отправки запросов к API. Запросы API обрабатываются за 0.1 секунду, а поиск в многомерном массиве происходит за 0.03 секунды. Тестировал при помощи этой конструкции:
Добавлено через 11 минут UDP: нет, вынес функции в отдельные переменные так, чтобы они не вызывались там, где выводятся значения. Стало ещё хуже. Похоже, у меня неправильно организовано подключение функций. Там нужно пилить классами, а я в этом совсем не разбираюсь ещё.
0
|
|||||||||||
|
3687 / 964 / 114
Регистрация: 10.01.2010
Сообщений: 2,550
|
|
| 13.10.2016, 21:17 | |
|
Для прохода по всем простым значениям массива на любом его уровне удобен array_walk_recursive
Для просмотра % вклада отдельных функций в работу страницы рекомендую xhprof, в частности, есть удобная библиотечка его результатов: http://github.com/staabm/xhprof.io
0
|
|
| 13.10.2016, 21:17 | |
|
Помогаю со студенческими работами здесь
10
Ускорение алгоритма поиска символов Ускорение поиска в ADO recordset Составить программу поиска элементов в массиве на основе метода двоичного поиска Написать программу поиска заданного значения в отсортированном массиве методом двоичного поиска Создать программу для поиска первого нечетного элемента в заданном массиве методом бинарного поиска Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|