Модераторы: skyboy, MoLeX, Aliance, ksnk
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> Преобразование массива 
:(
    Опции темы
SDEVIL
Дата 3.6.2010, 21:39 (ссылка) |    (голосов:1) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 243
Регистрация: 30.10.2006

Репутация: 1
Всего: 1



Есть такой массив:
Код

array(6) {
  0=>
  array(3) {
    "id"=>"1"
    "parent"=>"0"
    "title"=>"Раздел 1"
  }
  1=>
  array(3) {
    "id"=>"2"
    "parent"=>"0"
    "title"=>"Раздел 2"
  }
  2=>
  array(3) {
    "id"=>"3"
    "parent"=>"0"
    "title"=>"Раздел 3"
  }
  3=>
  array(3) {
    "id"=>"4"
    "parent"=>"1"
    "title"=>"Раздела 4"
  }
  4=>
  array(3) {
    "id"=>"5"
    "parent"=>"1"
    "title"=>"Раздела 5"
  }
  5=>
  array(3) {
    "id"=>"6"
    "parent"=>"4"
    "title"=>"Раздела 6"
  }
}

В массиве перечислены разделы все разделы сайта, с подразделами
Как отсортировать массив таким образом что бы все элементы шли по порядку т.е.:
Код

array(6) {
  0=>
  array(3) {
    "id"=>"1"
    "parent"=>"0"
    "title"=>"Раздел 1"
  }
  3=>
  array(3) {
    "id"=>"4"
    "parent"=>"1"
    "title"=>"Раздела 4"
  }
  5=>
  array(3) {
    "id"=>"6"
    "parent"=>"4"
    "title"=>"Раздела 6"
  }
  4=>
  array(3) {
    "id"=>"5"
    "parent"=>"1"
    "title"=>"Раздела 5"
  }
  1=>
  array(3) {
    "id"=>"2"
    "parent"=>"0"
    "title"=>"Раздел 2"
  }
  2=>
  array(3) {
    "id"=>"3"
    "parent"=>"0"
    "title"=>"Раздел 3"
  }
}

Т.е. за каждым родительским элементом шли его предки, но при этом размерность массива не должна меняться, т.е. из двумерного он не должен превращаться в многомерный. И еще бы при этом у каждого элемента добавился новый ключ level=>уровень вложенности.
Можно ли так отсортировать массив?
--------------------
Подпись сбежала к другому юзверю....
PM MAIL   Вверх
bars80080
Дата 3.6.2010, 23:28 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


прапор творюет
****
Награды: 1



Профиль
Группа: Завсегдатай
Сообщений: 12022
Регистрация: 5.12.2007
Где: Königsberg

Репутация: 71
Всего: 315



рекурсивная функция с циклом внутри, который прогоняет весь массив и ищет все совпадения

но это писать надо
PM MAIL WWW   Вверх
SDEVIL
Дата 3.6.2010, 23:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Бывалый
*


Профиль
Группа: Участник
Сообщений: 243
Регистрация: 30.10.2006

Репутация: 1
Всего: 1



bars80080
а тогда вопрос, что лучше: рекурсивной функцией сортировать массив или рекурсивной функцией получать готовое дерево из mysql?
Что будет боле оптимально и не так сильно грузить сервак?
--------------------
Подпись сбежала к другому юзверю....
PM MAIL   Вверх
SickFxck
Дата 3.6.2010, 23:48 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 107
Регистрация: 16.4.2010

Репутация: нет
Всего: 1



Если бы ты хранил дерево в Nested Sets, то такой бы проблемы не было вовсе.
PM MAIL   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
Правила форума "PHP"
Aliance
IZ@TOP
skyboy
SamDark
MoLeX

Новичкам:

  • PHP редакторы собираются и обсуждаются здесь
  • Электронные книги по PHP, документацию можно найти здесь
  • Интерпретатор PHP, полную документацию можно скачать на PHP.NET

Важно:

  • Не брезгуйте пользоваться тегами [code=php]КОД[/code] для повышения читабельности текста/кода.
  • Перед созданием новой темы воспользуйтесь поиском и загляните в FAQ
  • Действия модераторов можно обсудить здесь

Внимание:

  • Темы "ищу скрипт", "подскажите скрипт" и т.п. будут переноситься в форум "Web-технологии"
  • Темы с именами: "Срочно", "помогите", "не знаю как делать" будут УДАЛЯТЬСЯ

Если Вам понравилась атмосфера форума, заходите к нам чаще! С уважением, IZ@TOP, skyboy, SamDark, MoLeX, awers.

 
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | PHP: Общие вопросы | Следующая тема »


 




[ Время генерации скрипта: 0.1186 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.