欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法

 更新時(shí)間:2015年08月03日 14:56:42   作者:wxhlxx  
這篇文章主要介紹了php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法,實(shí)例分析了php排列組合數(shù)學(xué)運(yùn)算的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下

本文實(shí)例講述了php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:

<?php
set_time_limit(0);
/*
函數(shù)說(shuō)明:huoqu_zhuhe($eq,$jiashu,$isone=0)
參數(shù)說(shuō)明:$eq---幾個(gè)數(shù)相加的總和;
 $jiashu-------加數(shù)數(shù)組:$jiashu=array(1,2,3,4,5,6,7,8,9),可以使用的加數(shù);
 $isone---是否要每次使用不同的加數(shù),唯一性,1是 0 不,默認(rèn)1
返回類型:數(shù)組,數(shù)字以+相連的字符串:[0] => 3+8+9 [1] => 4+7+9
測(cè)試效果:1:對(duì)于加數(shù)數(shù)組比較小的,速度可以,過大的話,有些慢;2:每次可以使用不同的加數(shù)的,處理會(huì)變慢
采用的方法是:生成所有可能排列,對(duì)排列處理過濾重復(fù)的,得到組合
*/
function huoqu_zhuhe($eq,$jiashu,$isone=1)
{if(empty($jiashu)||!is_array($jiashu)){echo 'error:加數(shù)必須數(shù)組';return false;}
$feishu=0;
for($i=0;$i<count($jiashu);$i++){
if(!is_numeric($jiashu[$i])){$feishu=1;break;}
}
if($feishu==1){echo 'error;數(shù)組中必須是合法的數(shù)字';return false;}
$lian=$jiashu;
$savearr=array();
while(!empty($lian)){
//echo 1;
$newarr=array();
$k=0;
for($i=0;$i<count($lian);$i++){
$lianstr=$lian[$i];
$arr=explode('+',$lianstr);
$nowhe=array_sum($arr);
//echo $nowhe;
for($j=0;$j<count($jiashu);$j++){
$savestr=$lianstr.'+'.$jiashu[$j];
if($isone==1&&in_array($jiashu[$j],$arr))continue;
if(($nowhe+$jiashu[$j])>$eq)break;
else if(($nowhe+$jiashu[$j])==$eq){
$savearr[]=$savestr;
}
else{$newarr[$k]=$savestr;$k++;}
}//end for($j=0;$j<count($jiashu)
}// end for($i=0;$i
$lian=$newarr;
}//end while(!empty($lian))
//print_r($savearr);
//生成組合部分,過濾重復(fù),2個(gè)數(shù)組以一個(gè)為參考,看另一個(gè)是否能通過移動(dòng)達(dá)到匹配,可以,過濾
$isguolu=array();//存儲(chǔ)對(duì)應(yīng)的id的取舍 0取 1舍
for($i=0;$i<count($savearr);$i++){
$isguolu[]=0;
}//初始化全部0
for($i=0;$i<count($savearr);$i++){
$arr1=explode('+',$savearr[$i]);
$len1=count($arr1);
for($j=$i+1;$j<count($savearr);$j++){
$arr2=explode('+',$savearr[$j]);
$len2=count($arr2);
if($len1!=$len2)continue;
if($isguolu[$j]==1)continue;
//比較$arr1和$arr2開始
$jishu=0;
for($i1=0;$i1<count($arr1);$i1++){
$a=$arr1[$i1];
$isyou=0;
for($i2=$i1;$i2<count($arr2);$i2++){
if($a==$arr2[$i2]){
$jishu++;
$isyou=1;
$t=$arr2[$i1];
$arr2[$i1]=$arr2[$i2];
$arr2[$i2]=$t;
break;
}
}//end for($i2=0
if($isyou==0)break;
}// end for($i1=0;$i1<count($arr1);
if($jishu==$len1)$isguolu[$j]=1;
}//end for($j=$i+1;
}//end for($i=0;$i<count($savearr);$i++)
//print_r($isguolu);
//根據(jù)過濾數(shù)組選擇
$newarr=array();
for($i=0;$i<count($savearr);$i++){
if($isguolu[$i]==0)$newarr[]=$savearr[$i];
}
//print_r($newarr);
return $newarr;
}
//下面是一個(gè)測(cè)試
//取用1,2,3,4,5,6,7,8,9相加所有等于20的組合
$jiashu=array(1,2,3,4,5,6,7,8,9);
$eq=20;
if($jieguo=huoqu_zhuhe($eq,$jiashu,1))print_r($jieguo);
?>

運(yùn)行結(jié)果如下:

Array
(
  [0] => 3+8+9
  [1] => 4+7+9
  [2] => 5+6+9
  [3] => 5+7+8
  [4] => 1+2+8+9
  [5] => 1+3+7+9
  [6] => 1+4+6+9
  [7] => 1+4+7+8
  [8] => 1+5+6+8
  [9] => 2+3+6+9
  [10] => 2+3+7+8
  [11] => 2+4+5+9
  [12] => 2+4+6+8
  [13] => 2+5+6+7
  [14] => 3+4+5+8
  [15] => 3+4+6+7
  [16] => 1+2+3+5+9
  [17] => 1+2+3+6+8
  [18] => 1+2+4+5+8
  [19] => 1+2+4+6+7
  [20] => 1+3+4+5+7
  [21] => 2+3+4+5+6
)

希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • PHP處理excel cvs表格的方法實(shí)例介紹

    PHP處理excel cvs表格的方法實(shí)例介紹

    PHP處理excel cvs表格想必有很多朋友對(duì)此還是很陌生的吧,下面以實(shí)例為大家介紹下,感興趣的朋友可以參考下哈,希望對(duì)你有所幫助
    2013-05-05
  • 淺析PHP原理之變量(Variables inside PHP)

    淺析PHP原理之變量(Variables inside PHP)

    我前面的文章中已經(jīng)講過,PHP的執(zhí)行是通過Zend engine(ZE, Zend引擎), ZE是用C編寫的,大家都知道C是一個(gè)強(qiáng)類型語(yǔ)言,也就是說(shuō),在C中所有的變量在它被聲明到最終銷毀,都只能保存一種類型的數(shù)據(jù)。 那么PHP是如何在ZE的基礎(chǔ)上實(shí)現(xiàn)弱類型的呢
    2013-08-08
  • PHP詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換

    PHP詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換

    PHP基礎(chǔ)篇詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換,討論ASCII碼對(duì)照表圖與字符轉(zhuǎn)換為十進(jìn)制、八進(jìn)制、十六進(jìn)制和HTML的方法
    2011-12-12
  • php操作excel文件 基于phpexcel

    php操作excel文件 基于phpexcel

    最近在工作中需要處理多語(yǔ)言的翻譯問題,翻譯都是寫在excel表格里面。為了處理方便我就保留中文和英文兩列。這樣需要將這些數(shù)據(jù)從excel中取出來(lái),然乎保存在excel的數(shù)組中,通過使用循環(huán)數(shù)組將相應(yīng)的數(shù)據(jù)放入到數(shù)據(jù)庫(kù)中。
    2010-07-07
  • PHP使用 Pear 進(jìn)行安裝和卸載包的方法詳解

    PHP使用 Pear 進(jìn)行安裝和卸載包的方法詳解

    這篇文章主要介紹了PHP使用 Pear 進(jìn)行安裝和卸載包的方法,結(jié)合實(shí)例形式詳細(xì)分析了php使用 Pear 安裝及卸載擴(kuò)展包的相關(guān)操作命令與使用技巧,需要的朋友可以參考下
    2019-07-07
  • PHP通過內(nèi)置函數(shù)memory_get_usage()獲取內(nèi)存使用情況

    PHP通過內(nèi)置函數(shù)memory_get_usage()獲取內(nèi)存使用情況

    這篇文章主要介紹了PHP通過內(nèi)置函數(shù)memory_get_usage()獲取內(nèi)存使用情況,需要的朋友可以參考下
    2014-11-11
  • 詳解php中curl返回false的解決辦法

    詳解php中curl返回false的解決辦法

    這篇文章主要介紹了php中curl返回false的解決辦法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 基于PHP一些十分嚴(yán)重的缺陷詳解

    基于PHP一些十分嚴(yán)重的缺陷詳解

    本篇文章是對(duì)PHP中一些十分嚴(yán)重的缺陷進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-06-06
  • PHP+Apache實(shí)現(xiàn)二級(jí)域名之間共享cookie的方法

    PHP+Apache實(shí)現(xiàn)二級(jí)域名之間共享cookie的方法

    這篇文章主要介紹了PHP+Apache實(shí)現(xiàn)二級(jí)域名之間共享cookie的方法,涉及Apache的配置、hosts修改及php cookie操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2019-07-07
  • 分析PHP中單雙引號(hào)的誤區(qū)和雙引號(hào)小隱患

    分析PHP中單雙引號(hào)的誤區(qū)和雙引號(hào)小隱患

    PHP中單雙引號(hào)常常會(huì)給人帶來(lái)很多的誤區(qū),其中雙引號(hào)還有些小隱患,下面是小編給大家整理的,需要的可以參考。
    2016-07-07

最新評(píng)論