php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法
本文實(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原理之變量(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-08PHP詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換
PHP基礎(chǔ)篇詳解ASCII碼對(duì)照表與字符轉(zhuǎn)換,討論ASCII碼對(duì)照表圖與字符轉(zhuǎn)換為十進(jìn)制、八進(jìn)制、十六進(jìn)制和HTML的方法2011-12-12PHP通過內(nèi)置函數(shù)memory_get_usage()獲取內(nèi)存使用情況
這篇文章主要介紹了PHP通過內(nèi)置函數(shù)memory_get_usage()獲取內(nèi)存使用情況,需要的朋友可以參考下2014-11-11PHP+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)常常會(huì)給人帶來(lái)很多的誤區(qū),其中雙引號(hào)還有些小隱患,下面是小編給大家整理的,需要的可以參考。2016-07-07