PHP在相似元素上组合数组

Posted

技术标签:

【中文标题】PHP在相似元素上组合数组【英文标题】:PHP combine arrays on similar elements 【发布时间】:2013-05-22 17:39:11 【问题描述】:

我有一些这种格式的数据:

even--heaped<br />
even--trees<br />
hardrocks-cocked<br />
pebble-temple<br />
heaped-feast<br />
trees-feast<br />

我想最终得到一个输出,以便所有具有相同单词的行相互添加而不会重复。

even--heaped--trees--feast<br />
hardrocks--cocked<br />
pebbles-temple<br />

我尝试了一个遍历两个数组的循环,但它不是我想要的确切结果。对于数组 $thing:

Array ( [0] => even--heaped [1] => even--trees [2] => hardrocks--cocked [3] => pebbles--temple [4] => heaped--feast [5] => trees--feast )



for ($i=0;$i<count($thing);$i++)
    for ($j=$i+1;$j<count($thing);$j++)
        $first = explode("--",$thing[$i]);
        $second = explode("--",$thing[$j]);

        $merge = array_merge($first,$second);
        $unique = array_unique($merge);

    if (count($unique)==3)
        $fix = implode("--",$unique);
        $out[$i] = $thing[$i]."--".$thing[$j];
    





print_r($out);

但结果是:

Array ( [0] => even--heaped--heaped--feast [1] => even--trees--trees--feast [4] => heaped--feast--trees--feast )

这不是我想要的。任何建议(对糟糕的variable names 感到抱歉)。

【问题讨论】:

请提供$thing数组 阵列 ( [0] => 偶数--堆的 [1] => 偶数--树 [2] => 硬岩--竖起的 [3] => 鹅卵石--寺庙 [4] = > 堆--盛宴 [5] => 树--盛宴) 【参考方案1】:

这可能会对您有所帮助:

$in = array( 
    "even--heaped",
    "even--trees",
    "hardrocks--cocked",
    "pebbles--temple",
    "heaped--feast",
    "trees--feast"
);

$clusters = array();

foreach( $in as $item ) 

    $words = explode("--", $item);

    // check if there exists a word in an existing cluster...
    $check = false;
    foreach($clusters as $k => $cluster) 
        foreach($words as $word) 
            if( in_array($word, $cluster) ) 
                // add the words to this cluster
                $clusters[$k] = array_unique( array_merge($cluster, $words) );
                $check = true;
                break;
            
        
    

    if( !$check ) 
        // create a new cluster
        $clusters[] = $words;
    


// merge back
$out = array();
foreach( $clusters as $cluster ) 
    $out[] = implode("--", $cluster);


pr($out);

【讨论】:

我使用了相同的方法,但使用哈希而不是数组。检查哈希键效率更高,然后为每次迭代做 array_unique / array_merge。【参考方案2】:

试试这个代码:

<?php
$data = array ("1--2", "3--1", "4--5", "2--6");

$n = count($data);
$elements = array();
for ($i = 0; $i < $n; ++$i)

      $split = explode("--", $data[$i]);
      $word_num = NULL;

      foreach($split as $word_key => $word)
      
            foreach($elements as $key => $element)
            
                  if(isset($element[$word]))
                  
                        $word_num = $key;
                        unset($split[$word_key]);
                  
             

      

      if(is_null($word_num))
      
            $elements[] = array();
            $word_num = count($elements) - 1;
      
      foreach($split as $word_key => $word)
      
            $elements[$word_num][$word] = 1;
      


//combine $elements into words
foreach($elements as $key => $value)

      $words = array_keys($value);
      $elements[$key] = implode("--", $words);


var_dump($elements);

它使用 $elements 作为哈希数组来存储单个唯一单词作为键。然后组合键以创建适当的单词。

打印这个:

array(2) 
  [0]=>
  string(10) "1--2--3--6"
  [1]=>
  string(4) "4--5"

【讨论】:

@user2426240 通过使用 unset 而不是将元素标记为 NULL,稍微改进了答案【参考方案3】:

这是一个具有简单控制流的解决方案。

<?php
    $things = array('even--heaped', 'even--trees', 'hardrocks--cocked', 
        'pebble--temple', 'heaped--feast' ,'trees--feast');

    foreach($things as $thing) 
        $str = explode('--', $thing);
        $first = $str[0];
        $second = $str[1];
        $i = '0';
        while(true) 
            if(!isset($a[$i])) 
                $a[$i] = array();
                array_push($a[$i], $first);
                array_push($a[$i], $second);
                break;
             else if(in_array($first, $a[$i]) && !in_array($second, $a[$i])) 
                array_push($a[$i], $second);
                break;
             else if(!in_array($first, $a[$i]) && in_array($second, $a[$i])) 
                array_push($a[$i], $first);
                break;
             else if(in_array($first, $a[$i]) && in_array($second, $a[$i])) 
                break;
            
            $i++;
        

    
    print_r($a);
?>

【讨论】:

【参考方案4】:

看来你已经选择user4035的答案为最佳。

但我觉得这个是优化的(如果我错了请纠正我):eval.in

代码:

$array = Array ( 'even--heaped' , 'even--trees' ,'hardrocks--cocked' , 'pebbles--temple' , 'heaped--feast' , 'trees--feast' );
print "Input: ";
print_r($array);

for($j=0;$j < count($array);$j++)
    $len = count($array);
    for($i=$j+1;$i < $len;$i++)
        $tmp_array = explode("--", $array[$i]);
        $pos1 = strpos($array[$j], $tmp_array[0]);
        $pos2 = strpos($array[$j], $tmp_array[1]);

        if (!($pos1 === false) && $pos2 === false)
            $array[$j] = $array[$j] . '--'.$tmp_array[1];unset($array[$i]);
        elseif(!($pos2 === false) && $pos1 === false)
            $array[$j] = $array[$j] . '--'.$tmp_array[0];unset($array[$i]);
        elseif(!($pos2 === false) && !($pos1 === false))
            unset($array[$i]);
        
    
    $array = array_values($array);


print "\nOutput: ";
print_r($array);

【讨论】:

以上是关于PHP在相似元素上组合数组的主要内容,如果未能解决你的问题,请参考以下文章

JAVA中的数组合并问题

php下将多个数组合并成一个数组的方法与实例代码

c++两个数组合并成一个新数组

在PHP中查找数组元素的所有可能的唯一组合[重复]

php当中,如何将数组合并成变量呢?

数组元素的PHP组合