|
5 / 4 / 4
Регистрация: 03.09.2012
Сообщений: 91
|
||||||
Лучший способ перебора01.02.2013, 14:28. Показов 3878. Ответов 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
Лучший способ апгрейда Способ расчета без перебора Лучший способ сохранения настроек Лучший способ доступа в инет
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут
Суть:
- Группа наркоманов из 10 человек.
- Только один инфицирован ВИЧ.
- Колются одной иглой.
- Колются раз в день.
- Колются последовательно через. . .
|
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
|
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
|
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|
|
Фиксация колонок в отчете СКД
Maks 14.04.2026
Фиксация колонок в СКД отчета типа Таблица.
Задача: зафиксировать три левых колонки в отчете.
Процедура ПриКомпоновкеРезультата(ДокументРезультат, ДанныеРасшифровки, СтандартнаяОбработка)
/ / . . .
|
Настройки VS Code
Loafer 13.04.2026
{
"cmake. configureOnOpen": false,
"diffEditor. ignoreTrimWhitespace": true,
"editor. guides. bracketPairs": "active",
"extensions. ignoreRecommendations": true,
. . .
|
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2.
Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива.
Было так:. . .
|
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2.
Задача: реализовать контроль корректности заполнения дат назначения. . .
|