Frage

Ich habe Paare von Elementen in einem PHP-Array. Beispiel:

<?php
$elements = array(
    'tiger'=>'lion',
    'car'=>'bike',
    'lion'=>'zoo',
    'truck'=>'plane'
);
?>

Jetzt möchte ich diese Elemente kombinieren, so dass alle Elemente, die in irgendeiner Art und Weise zu einer Gruppe gehen verbunden sind. Fortsetzung des obigen Beispiels:

<?php
$groups = array(
    0=>array('tiger', 'lion', 'zoo'),
    1=>array('car', 'bike'),
    2=>array('truck', 'plane'
);
?>

Ist das verständlich? Wie kann ich erreichen das?

Ich suche nach einer Funktion, die dies tut.

War es hilfreich?

Lösung

<?php

$elements = array(
    'tiger' => 'lion',
    'car' => 'bike',
    'lion' => 'zoo',
    'truck' => 'plane'
);

$groups = array();

foreach ($elements as $key => $val) {
    $appended = false;
    foreach ($groups as &$group) {
        if ($group[0] == $key) {
            array_unshift($group, $val);
            $appended = true;
            break;
        }
    }
    if (!$appended) {
        $groups[] = array($val, $key);
    }
}

var_dump($groups);

Gibt:

array(3) {
  [0]=>
  array(3) {
    [0]=>
    string(3) "zoo"
    [1]=>
    string(4) "lion"
    [2]=>
    string(5) "tiger"
  }
  [1]=>
  &array(2) {
    [0]=>
    string(4) "bike"
    [1]=>
    string(3) "car"
  }
  [2]=>
  array(2) {
    [0]=>
    string(5) "plane"
    [1]=>
    string(5) "truck"
  }
}

Andere Tipps

Hier ist eine O (n) Lösung:

$elements = array(
    'tiger' => 'lion',
    'car'   => 'bike',
    'lion'  => 'zoo',
    'truck' => 'plane'
);
$groups = array();
$sub    = array();
$ignore = array();

foreach ( $elements as $key=>$value ) {
    if ( isset($ignore[$key]) ) {
        continue;
    }

    $sub = array($key, $value);

    if ( isset($elements[$value]) ) {
        $ignore[$value] = 1;
        $sub[]          = $elements[$value];
    }

    $groups[] = $sub;
}

print_r($groups);

Ergebnis:

Array
(
    [0] => Array
        (
            [0] => tiger
            [1] => lion
            [2] => zoo
        )

    [1] => Array
        (
            [0] => car
            [1] => bike
        )

    [2] => Array
        (
            [0] => truck
            [1] => plane
        )

)

Die Idee ist einfach:

  1. Erstellen Sie ein neues Array Ihre Gruppen halten
  2. Schleife über das Element Array
  3. Überprüfen Sie, ob die Gruppe für das Element in der Gruppe Array existiert - wenn dies nicht der Fall, erstellen Sie es
  4. einstellen Artikel in der Gruppe
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top