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

2025-05-29 0 65

本文实例讲述了php通过排列组合实现1到9数字相加都等于20的方法。分享给大家供大家参考。具体实现方法如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90
<?php

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<count($jiashu);$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<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);

//生成组合部分,过滤重复,2个数组以一个为参考,看另一个是否能通过移动达到匹配,可以,过滤

$isguolu=array();//存储对应的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);

//根据过滤数组选择

$newarr=array();

for($i=0;$i<count($savearr);$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);

?>

运行结果如下:

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25
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程序设计有所帮助。

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 php通过排列组合实现1到9数字相加都等于20的方法 https://www.kuaiidc.com/100534.html

相关文章

发表评论
暂无评论