|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
||||||
Лучший способ перебора01.02.2013, 14:28. Показов 3854. Ответов 13
Метки нет (Все метки)
Не знал как назвать тему. В общем проблема в следующем.
Есть 20-25 массивов по 10-30 элементами. Приведу пример с меньшим количеством скажем 3 массива по 4 элемента. Пользователь вводит в поле одно число, допустим 5000. Скрипт должен показать при сложении каких элементов массивов результат получится число, которое ввел пользователь, т.е. в нашем случае 5000. При сложении из каждого массива берется только 1 элемент. К примеру, $a1 = array("0", "500", "1000", "2300"); $a2 = array("200", "1400", "1600", "4000"); $a3 = array("0", "1100", "2900", "3100"); Результат должен быть типа таким: 1. $a1[1] + $a2[1] + $a3[3] равно 5000 2. $a1[1] + $a2[2] + $a3[2] равно 5000 3. $a1[2] + $a2[3] равно 5000 4. $a1[3] + $a2[2] + $a3[1] равно 5000 я написал такой код:
такого компа в ближайшем будущем я не найду, поэтому нужен совет, может быть есть какой нибудь более простой способ перебора элементов массивов?
0
|
||||||
| 01.02.2013, 14:28 | |
|
Ответы с готовыми решениями:
13
Дорогие знатоки! Какой по вашему мнению самый лучший способ перевести кракозябры на русский? Лучший способ идентификации и аутентификации (Auth0/Firebase) Прошу предложить лучший вариант перебора массива |
|
87 / 87 / 8
Регистрация: 02.09.2012
Сообщений: 510
|
|
| 01.02.2013, 15:36 | |
|
Архитектурная ошибка. Для подобного поиска используются не массивы, а деревья... Как вариант:организовать деревья в виде вложенных множеств
0
|
|
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
|
| 04.02.2013, 13:45 [ТС] | |
|
прочитал несколько статей на эту темку, но так и не до понял. может напишите как делается?
0
|
|
|
|
|
| 04.02.2013, 14:10 | |
|
1. Ускорить работу могло бы хранение чисел не в виде строк, а в виде чисел.
2. Работа пошла бы еще быстрее, если написать перебор на компилируемом языке (си, дельфи) и подключить к PHP. Как это сделать я не знаю, но знаю, что это возможно. 3. Если бы про сами числа было известно больше, (например, все числа неотрицательны), то можно было бы сэкономить на алгоритме. А когда про числа ничего не известно, то оптимальней вашего сам алгоритм написать, по-моему, нельзя.
1
|
|
|
603 / 578 / 103
Регистрация: 16.07.2012
Сообщений: 1,762
|
|
| 04.02.2013, 18:17 | |
|
вот немного похожая задача на вашу https://www.youtube.com/watch?v=iNTmu2STGGQ
1
|
|
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
||
| 07.02.2013, 15:07 [ТС] | ||
|
2. На Си пока не пробовал, если пхп не справится с задачей, тогда попробую. 3. Числа в диапазоне от 0-2000. Что посоветуете изменить в алгоритме?
0
|
||
|
|
||||||
| 07.02.2013, 15:27 | ||||||
|
Если первые числа большие, так что сумма заведомо превысит $сhislo, то цикл можно прервать и не заниматься перебором чисел из второго и третьего массивов. Можно кое-что вычислить перед циклом, чтобы многократно не вычислять одно и то же внутри цикла.
1
|
||||||
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
||||||||||||||||
| 07.02.2013, 17:06 | ||||||||||||||||
|
Где-то тут лишняя скобка, ну да это не проблема найти.
Добавлено через 16 минут Упс, по поводу скорости и памяти я не прав. http://php.net/manual/ru/contr... es.for.php . Хотя раньше находил инфу, что count, куда-то запоминается)
1
|
||||||||||||||||
|
155 / 25 / 6
Регистрация: 06.06.2009
Сообщений: 262
|
||||||||||||
| 07.02.2013, 17:11 | ||||||||||||
1
|
||||||||||||
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
||||||||||||||||
| 07.02.2013, 17:48 | ||||||||||||||||
|
Не поленился и тоже провел эксперимент из 3-х циклов. Размер массива 30 элементов, количество итераций оставил такое же (10000000).
1
|
||||||||||||||||
|
41 / 40 / 16
Регистрация: 23.03.2010
Сообщений: 3,122
|
||||||
| 07.02.2013, 17:56 | ||||||
|
Sherzant не знаю правильно ли я понял но почему бы не использовать foreach?
0
|
||||||
|
603 / 578 / 103
Регистрация: 16.07.2012
Сообщений: 1,762
|
|||||||
| 07.02.2013, 19:03 | |||||||
0
|
|||||||
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
|||||||
| 08.02.2013, 12:53 | |||||||
0
|
|||||||
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
||
| 12.02.2013, 16:25 [ТС] | ||
|
Спасибо и экспериментаторам oke11o, hellmin )) узнал новые методы Добавлено через 6 минут нет, вы меня не совсем поняли. если не ошибаюсь ваша функция сложит все элементы одного массива и выводит общую сумму. а мне надо чтобы в результат входил максимум по 1 элементу из всех массивов. такой подход действительно интересный, сейчас попробую) Добавлено через 1 час 4 минуты действительно для этой задачки метод foreach оказался лучше. для теста использовал 5 массивов с 30 элементами. метод for обработал и вывел результаты за 12.429224968 секунд. метод foreach за 7.36549782753 секунд.
0
|
||
| 12.02.2013, 16:25 | |
|
Помогаю со студенческими работами здесь
14
Лучший способ апгрейда Способ расчета без перебора Лучший способ сохранения настроек Лучший способ доступа в инет
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера 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. Пошагово создадим проект для загрузки изображения. . .
|