|
|
|
Алгоритм преобразования линейного массива в многомерный и наоборот
|
|||
|---|---|---|---|
|
#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, 08:28 |
|
||
|
Алгоритм преобразования линейного массива в многомерный и наоборот
|
|||
|---|---|---|---|
|
#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:54 |
|
||
|
Алгоритм преобразования линейного массива в многомерный и наоборот
|
|||
|---|---|---|---|
|
#18+
P.S. Единственное отличие от требуемого варианта - это все пустые child равны не false, а пустому массиву [] ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.05.2013, 10:56 |
|
||
|
Алгоритм преобразования линейного массива в многомерный и наоборот
|
|||
|---|---|---|---|
|
#18+
Програмёр, спасибо! Буду курить) Сам делал рекурсией, а тут что-то новое. Вместо false можно [] использовать. Не принципиально ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.05.2013, 11:47 |
|
||
|
Алгоритм преобразования линейного массива в многомерный и наоборот
|
|||
|---|---|---|---|
|
#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, только более линейно, быстрее и легче. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 12.05.2013, 12:16 |
|
||
|
|

start [/forum/topic.php?fid=22&msg=38254100&tid=1448362]: |
0ms |
get settings: |
6ms |
get forum list: |
20ms |
check forum access: |
3ms |
check topic access: |
3ms |
track hit: |
254ms |
get topic data: |
14ms |
get forum data: |
4ms |
get page messages: |
63ms |
get tp. blocked users: |
2ms |
| others: | 213ms |
| total: | 582ms |

| 0 / 0 |
