5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
||||||
1 | ||||||
Лучший способ перебора01.02.2013, 14:28. Показов 3396. Ответов 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 | 2 |
Архитектурная ошибка. Для подобного поиска используются не массивы, а деревья... Как вариант:организовать деревья в виде вложенных множеств
0
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
|
04.02.2013, 13:45 [ТС] | 3 |
прочитал несколько статей на эту темку, но так и не до понял. может напишите как делается?
0
|
04.02.2013, 14:10 | 4 |
1. Ускорить работу могло бы хранение чисел не в виде строк, а в виде чисел.
2. Работа пошла бы еще быстрее, если написать перебор на компилируемом языке (си, дельфи) и подключить к PHP. Как это сделать я не знаю, но знаю, что это возможно. 3. Если бы про сами числа было известно больше, (например, все числа неотрицательны), то можно было бы сэкономить на алгоритме. А когда про числа ничего не известно, то оптимальней вашего сам алгоритм написать, по-моему, нельзя.
1
|
603 / 578 / 103
Регистрация: 16.07.2012
Сообщений: 1,762
|
|
04.02.2013, 18:17 | 5 |
вот немного похожая задача на вашу https://www.youtube.com/watch?v=iNTmu2STGGQ
1
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
|
07.02.2013, 15:07 [ТС] | 6 |
1. Элементы массива теперь как числа. Быстродействие скрипта увеличился на 25-35% (950000 операций вместо старых 700000).
2. На Си пока не пробовал, если пхп не справится с задачей, тогда попробую. 3. Числа в диапазоне от 0-2000. Что посоветуете изменить в алгоритме?
0
|
07.02.2013, 15:27 | 7 | |||||
Если первые числа большие, так что сумма заведомо превысит $сhislo, то цикл можно прервать и не заниматься перебором чисел из второго и третьего массивов. Можно кое-что вычислить перед циклом, чтобы многократно не вычислять одно и то же внутри цикла.
1
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
||||||||||||||||
07.02.2013, 17:06 | 8 | |||||||||||||||
Где-то тут лишняя скобка, ну да это не проблема найти.
Добавлено через 16 минут Упс, по поводу скорости и памяти я не прав. http://php.net/manual/ru/contr... es.for.php . Хотя раньше находил инфу, что count, куда-то запоминается)
1
|
155 / 25 / 6
Регистрация: 06.06.2009
Сообщений: 262
|
||||||
07.02.2013, 17:11 | 9 | |||||
Вроде скоростью тоже. Поставил эксперимент:
Код
Вывод: Время count() - 6.8720488548279sec Время $count - 2.5031878948212sec
1
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
||||||
07.02.2013, 17:48 | 10 | |||||
Не поленился и тоже провел эксперимент из 3-х циклов. Размер массива 30 элементов, количество итераций оставил такое же (10000000).
Код
Время count() - 69.72768497467sec Время $count - 19.816310882568sec Время $count - 21.433360099792sec Код
Время count() - 135.37351417542sec Время $count - 38.991626977921sec Время $count - 40.667366981506sec
1
|
41 / 42 / 16
Регистрация: 23.03.2010
Сообщений: 3,069
|
||||||
07.02.2013, 17:56 | 11 | |||||
Sherzant не знаю правильно ли я понял но почему бы не использовать foreach?
0
|
603 / 578 / 103
Регистрация: 16.07.2012
Сообщений: 1,762
|
||||||
07.02.2013, 19:03 | 12 | |||||
не пишите так, при такой записи на каждой итерации цикла производится подсчет елементов функцией count, хотя это значение достаточно посчитать один раз
0
|
36 / 36 / 9
Регистрация: 13.07.2011
Сообщений: 95
|
||||||
08.02.2013, 12:53 | 13 | |||||
А ведь и правда... при количестве элементов массива 40 разница по времени в два раза.
0
|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
|
12.02.2013, 16:25 [ТС] | 14 |
об этом как то не подумал, хороший совет, спасибо)
Спасибо и экспериментаторам oke11o, hellmin )) узнал новые методы Добавлено через 6 минут нет, вы меня не совсем поняли. если не ошибаюсь ваша функция сложит все элементы одного массива и выводит общую сумму. а мне надо чтобы в результат входил максимум по 1 элементу из всех массивов. такой подход действительно интересный, сейчас попробую) Добавлено через 1 час 4 минуты действительно для этой задачки метод foreach оказался лучше. для теста использовал 5 массивов с 30 элементами. метод for обработал и вывел результаты за 12.429224968 секунд. метод foreach за 7.36549782753 секунд.
0
|
12.02.2013, 16:25 | |
Помогаю со студенческими работами здесь
14
Способ расчета без перебора Лучший способ сохранения настроек Лучший способ доступа в инет
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |