日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > php >内容正文

php

php输出1到10的和,php通过排列组合实现1到9数字相加都等于20的方法

發布時間:2025/3/15 php 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 php输出1到10的和,php通过排列组合实现1到9数字相加都等于20的方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

set_time_limit(0);

/*

函數說明:huoqu_zhuhe($eq,$jiashu,$isone=0)

參數說明:$eq---幾個數相加的總和;

$jiashu-------加數數組:$jiashu=array(1,2,3,4,5,6,7,8,9),可以使用的加數;

$isone---是否要每次使用不同的加數,唯一性,1是 0 不,默認1

返回類型:數組,數字以+相連的字符串:[0] => 3+8+9 [1] => 4+7+9

測試效果:1:對于加數數組比較小的,速度可以,過大的話,有些慢;2:每次可以使用不同的加數的,處理會變慢

采用的方法是:生成所有可能排列,對排列處理過濾重復的,得到組合

*/

function huoqu_zhuhe($eq,$jiashu,$isone=1)

{if(empty($jiashu)||!is_array($jiashu)){echo 'error:加數必須數組';return false;}

$feishu=0;

for($i=0;$i

if(!is_numeric($jiashu[$i])){$feishu=1;break;}

}

if($feishu==1){echo 'error;數組中必須是合法的數字';return false;}

$lian=$jiashu;

$savearr=array();

while(!empty($lian)){

//echo 1;

$newarr=array();

$k=0;

for($i=0;$i

$lianstr=$lian[$i];

$arr=explode('+',$lianstr);

$nowhe=array_sum($arr);

//echo $nowhe;

for($j=0;$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

}// end for($i=0;$i

$lian=$newarr;

}//end while(!empty($lian))

//print_r($savearr);

//生成組合部分,過濾重復,2個數組以一個為參考,看另一個是否能通過移動達到匹配,可以,過濾

$isguolu=array();//存儲對應的id的取舍 0取 1舍

for($i=0;$i

$isguolu[]=0;

}//初始化全部0

for($i=0;$i

$arr1=explode('+',$savearr[$i]);

$len1=count($arr1);

for($j=$i+1;$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

$a=$arr1[$i1];

$isyou=0;

for($i2=$i1;$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

if($jishu==$len1)$isguolu[$j]=1;

}//end for($j=$i+1;

}//end for($i=0;$i

//print_r($isguolu);

//根據過濾數組選擇

$newarr=array();

for($i=0;$i

if($isguolu[$i]==0)$newarr[]=$savearr[$i];

}

//print_r($newarr);

return $newarr;

}

//下面是一個測試

//取用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);

?>

運行結果如下:

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

)

希望本文所述對大家的php程序設計有所幫助。

總結

以上是生活随笔為你收集整理的php输出1到10的和,php通过排列组合实现1到9数字相加都等于20的方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。