|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
||||||||||||||||||||||||||
Обращение через индекс Dictionary или IndexOf, что быстрее / производительнее?20.07.2015, 17:36. Показов 5149. Ответов 17
Смотрите есть строка:
а потом просто:
Работы будет много, по этому это важно. PS я может туплю, просто в последнее время занимался РНР, а там есть способ так обращаться и оно работает быстрее чем поиск по массиву, вот и спрашиваю.
вроде как когда я через индекс обращаюсь, там все равно поиск осуществляется перебором.
0
|
||||||||||||||||||||||||||
| 20.07.2015, 17:36 | |
|
Ответы с готовыми решениями:
17
Что выполнится быстрее - With-End with или просто обращение к ячейке? Как будет быстрее и производительнее: проверять существование файла или обрабатывать исключение |
|
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,102
|
|||||||
| 20.07.2015, 17:57 | |||||||
|
при такой длинне строки IndexOf должен быть быстрее
а если это реальная строка:
1
|
|||||||
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
|
| 20.07.2015, 18:22 [ТС] | |
|
XRoy, эммм.. я не так силен в математике, можно так на словах, что все же будет быстрее
Добавлено через 1 минуту nedel, ну вообще строчка может быть дополнена любыми символами, по этому все же лучше так считать.
0
|
|
| 20.07.2015, 18:32 | |
|
VLK,
Когда количество запрсов в квадрате больше длины строки, то используйте словарь, иначе IndexOf Более простыми словами, при большом количестве запросов к короткой строке нужен словарь, если длинная строка и малое количество запросов, то IndexOf Следует учесть что это расчеты для худших случаев
1
|
|
|
1167 / 885 / 517
Регистрация: 09.04.2014
Сообщений: 2,102
|
|||
| 20.07.2015, 18:33 | |||
|
1
|
|||
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
||
| 20.07.2015, 18:55 [ТС] | ||
|
спасибо, подскажите еще такую вещь, Array.BinarySearch в данном случае может помочь, строка в которой надо будет осуществлять поиск, по длине будет ну где то:
запросов будет много.
0
|
||
|
Master of Orion
|
|
| 20.07.2015, 19:00 | |
|
VLK, да что нужно-то?
Если проверить, есть ли символ в таблице, это HashSet. Если найти позицию в строке (причем работает конечно же только на сортированной) - можно BinarySearch'ем пройтись. Если найти позицию в несортированной строке, то IndexOf. и так далее. Я понимаю, что после PHP это трудно, но стоит постараться думаю.
0
|
|
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
||||||
| 20.07.2015, 19:01 [ТС] | ||||||
|
Psilon, сейчас ни какой конкретной задачи нет, когда то давно писал код для перебора разных комбинаций, что то типа подбора пароля, сейчас нашел этот код и решил переписать все "по уму", вот что написал:
0
|
||||||
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
|
| 20.07.2015, 19:11 [ТС] | |
|
Psilon, если передать словарь abcdefghijklmnopqrstuvwxyz и слово aba в результате я получу в ответ abb, как какая логика, допустим мне надо перебрать пароли, и я могу продолжить перебор с какого-нибудь конкретного места.
Добавлено через 1 минуту я помню все это еще началось на форуме РНР, там какому то надо было перебирать пароли, некоторые стали писать, я тоже попробовал, но у меня получилась тонна кода и толком не работало, сейчас вот нашел, решил по новой сделать. Ну и мало ли где то понадобиться еще.
0
|
|
|
Master of Orion
|
|
| 20.07.2015, 19:17 | |
|
VLK, ну тут тогда можно вообще на скорость забить, поиск на строке из 30 символов занимает 961 тактов на моем 3770k, учитывая частоту 3.4ГГц это 283 наносекунды. Что тут оптимизировать - непонятно.
2
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
|
| 21.07.2015, 12:17 | |
|
0
|
|
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
||
| 21.07.2015, 12:59 [ТС] | ||
|
я забил, за тестировал Array.IndexOf и Array.BinarySearch все зависит от длинны, если словарь "0123456789", то быстрее IndexOf, а если "abcdefghijklmnopqrstuvwxyz" то уже быстрее BinarySearch, хотя разница там микро, короче я решил остановиться на IndexOf и все.
0
|
||
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 21.07.2015, 13:19 | ||
|
Если в будущем это место станет проблемой, то тогда уже можно будет и оптимизировать.
0
|
||
|
198 / 170 / 19
Регистрация: 05.05.2013
Сообщений: 1,236
|
|
| 21.07.2015, 13:47 [ТС] | |
|
kolorotur, а где можно посмотреть вот эти формулы, только в короткой и понятной форме (статье), а то вы все их пишите, а я толком не догоняю что к чему.
0
|
|
|
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
|
||
| 21.07.2015, 14:42 | ||
|
Может, где-то проще расписано, не знаю. Если вы про то, у какого алгоритма какая сложность в O, то просто гляньте соответствующий алгоритм на той же википедии — там будет справа табличка. Почти для всех классов-коллекций в .NET документация указывает сложность добавления, поиска и удаления элемента. Для своих алгоритмов сложность можете расчитать сами, тут где-то недавно была тема о том, как это делается.
1
|
||
| 21.07.2015, 14:42 | |
|
Помогаю со студенческими работами здесь
18
List<T>.Contains() и Dictionary<T, T>.ContainsKey(): что быстрее Что быстрее? Обращение к элементу массива или к элементу структуры? Обращение к Dictionary через свойство
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога
Финальные проекты на Си и на C++:
hello-sdl3-c. zip
hello-sdl3-cpp. zip
Результат:
|
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога
MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
|
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд.
Даже если у вас. . .
|
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает
монорепозиторий в котором находятся все исходники.
При создании нового решения, мы просто добавляем нужные проекты
и имеем. . .
|
|
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение:
В этой книге («Подход, основанный на вариантах использования») Ивар утверждает,
что архитектура программного обеспечения — это
структуры,. . .
|
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога
Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
|
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 Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|