PHP排列组合算法

  一直对算法很感兴趣,去年初培训iOS的时候老师在课堂上出了个排列的题目看谁能最先说出想法,但并不要求立即编码实现,当时北科大一同学很快说出了可行的办法得到了老师的肯定,听似简单但并不是想象的那么容易理解,后来各种事就没有细想了。

  其实早在大学时代我就尝试用C写过彩票的排列,当时玩过一段时间福彩3D和体彩排列三,企图通过计算机来筛选可能的中奖号码,那时才疏学浅完全是兴趣驱动,幸好当时没有经济来源,有限的生活费被我败光后及时走出了这条不归路。

  最近做的手游项目中说是需要排列组合的算法,我现在虽然做客户端了但是PHP还是比较熟悉的,于是就自己练练手试着写写看,出人意料的是原来PHP的数组函数用着如此方便,这么几行就搞定了,现在分享给大家,不足之处还望多多指教。

<?php

// 阶乘
function factorial($n) {
	return array_product(range(1, $n));
}

// 排列数
function A($n, $m) {
	return factorial($n)/factorial($n-$m);
}

// 组合数
function C($n, $m) {
	return A($n, $m)/factorial($m);
}

// 排列
function arrangement($a, $m) {
	$r = array();

	$n = count($a);
	if ($m <= 0 || $m > $n) {
		return $r;
	}

	for ($i=0; $i<$n; $i++) {
		$b = $a;
		$t = array_splice($b, $i, 1);
		if ($m == 1) {
			$r[] = $t;
	
  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值