日期:2013-05-31  浏览次数:20551 次

<?php
/**
 *描述:把$input_arr进行组合操作,并返回一个包含所有组合的数组
 *参数:$input_arr 操作对象,$delimit 组合的分割符号,$n 每个组合的数组单元数
 *作者:surfchen@gmail.com
 *版权:任意复制,修改所有内容.
**/
function getSingleComb($input_arr,$delimit,$n)
{
 if ($n==1)
 {
  return $input_arr;
 }
 $c_num=getCNum($n,count($input_arr));
 $new_arr=array();
 while (1)
 {
  $r_arr=array_rand($input_arr,$n);
  asort($r_arr);
  foreach ($r_arr as $value)
  {
   $tmp_str[]=$input_arr[$value];
  }
  $new_str=implode($delimit,$tmp_str);
  unset($tmp_str);
  if (!in_array($new_str,$new_arr))
  {
   $new_arr[]=$new_str;
  }
  if (count($new_arr)>=$c_num)
  {
   break;
  }
 }
 return $new_arr;
 
}
/**
 *描述:获得组合(请参阅初等数学的排列与组合)个数
 *参数:$m 组合的单元数,$n 单元总数
 *作者:surfchen@gmail.com
 *版权:任意复制,修改所有内容.
**/
function getCNum($m,$n)
{
 $store_m=$m;
 $store_n=$n;
 $dividend=1;
 for ($m;$m>1;$m--)
 {
  $dividend*=$m;
 }
 $divisor=1;
 for ($n;$n>=($store_n-$store_m+1);$n--)
 {
  $divisor*=$n;
 }
 return $divisor/$dividend;
}
/**
 *描述:把$input_arr进行组合操作,并返回一个包含所有组合的数组
 *参数:$input_arr 操作对象,$delimit 组合的分割符号,$n_arr 为一个数组,其值范围必须在从1到count($input_arr)之间
 *作者:surfchen@gmail.com
 *版权:任意复制,修改所有内容.
**/
function getMultiComb($input_arr,$delimit,$n_arr)
{
 $return_arr=array();
 foreach ($n_arr as $value)
 {
  $return_arr=array_merge($return_arr,getSingleComb($input_arr,$delimit,$value));
 }
 return $return_arr;
}
$input_arr=explode(" ",'sina sohu yahoo baidu 163');
print_r(getMultiComb($input_arr," ",array(1,2,3,4)));
?>