
Новые сообщения [новые:0]
Дайджест
Горячие темы
Избранное [новые:0]
Форумы
Пользователи
Статистика
Статистика нагрузки
Мод. лог
Поиск
|
|
12.05.2013, 08:28
|
|||
|---|---|---|---|
Алгоритм преобразования линейного массива в многомерный и наоборот |
|||
|
#18+
Посоветуйте быстрый алгоритм, который из такого массива: Код: javascript 1. 2. 3. 4. 5. 6. 7. сделает такой: Код: javascript 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. и наоборот ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
12.05.2013, 10:54
|
|||
|---|---|---|---|
Алгоритм преобразования линейного массива в многомерный и наоборот |
|||
|
#18+
Shitbox2, Код: javascript 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. res - нужный массив... это преобразование с одномерного в многомерный на js. В обратную сторону ещё не придумал :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
12.05.2013, 10:56
|
|||
|---|---|---|---|
Алгоритм преобразования линейного массива в многомерный и наоборот |
|||
|
#18+
P.S. Единственное отличие от требуемого варианта - это все пустые child равны не false, а пустому массиву [] ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
12.05.2013, 11:47
|
|||
|---|---|---|---|
Алгоритм преобразования линейного массива в многомерный и наоборот |
|||
|
#18+
Програмёр, спасибо! Буду курить) Сам делал рекурсией, а тут что-то новое. Вместо false можно [] использовать. Не принципиально ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|
12.05.2013, 12:16
|
|||
|---|---|---|---|
Алгоритм преобразования линейного массива в многомерный и наоборот |
|||
|
#18+
Shitbox2Програмёр, спасибо! Буду курить) Сам делал рекурсией, а тут что-то новое. Вместо false можно [] использовать. Не принципиально упс... только сейчас заметил... сорри, не проверил код после добавления строки res = temp[0]. Данную строку надо заменить на res=temp[0].child. А так в принципе тут всё просто. Как мы знаем, объекты передаются по ссылкам. Тут обычная хитрость, я записываю объекты в один одномерный массив по их id, а потом просто начинаю вкладывать один в другой (при этом делаю это через одномерный массив, поэтому без рекурсий и кучи проходов по одному и тому же). То есть, элементы temp[5] и temp[2].child[0] указывают на тот же объект и temp[5].child.push() равносильно temp[2].child[0].child.push, только более линейно, быстрее и легче. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
|
|
|

start [/forum/topic.php?fid=22&tablet=1&tid=1448362]: |
0ms |
get settings: |
10ms |
get forum list: |
19ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
203ms |
get topic data: |
11ms |
get forum data: |
3ms |
get page messages: |
41ms |
get tp. blocked users: |
2ms |
| others: | 250ms |
| total: | 547ms |

| 0 / 0 |
