使用php計(jì)算排列組合的方法
更新時(shí)間:2013年11月13日 09:48:33 作者:
本文用PHP要解決的數(shù)學(xué)問(wèn)題是算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
前些天因?yàn)闃I(yè)務(wù)需要寫(xiě)了一段計(jì)算排列組合的代碼,今天整理了一下,以備后用
<?php
/**
* 要解決的數(shù)學(xué)問(wèn)題 :算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
*
* 要解決的實(shí)際問(wèn)題樣例:某年級(jí)有m個(gè)班級(jí),每個(gè)班的人數(shù)不同,現(xiàn)在要從每個(gè)班里抽選一個(gè)人組成一個(gè)小組,
* 由該小組來(lái)代表該年級(jí)參加學(xué)校的某次活動(dòng),請(qǐng)給出所有可能的組合
*/
/* ################################### 開(kāi)始計(jì)算 ################################### */
/**
* 需要進(jìn)行排列組合的數(shù)組
*
* 數(shù)組說(shuō)明:該數(shù)組是一個(gè)二維數(shù)組,第一維索引代表班級(jí)編號(hào),第二維索引代表學(xué)生編號(hào)
*/
$CombinList = array(1 => array("Student10", "Student11"),
2 => array("Student20", "Student21", "Student22"),
3 => array("Student30"),
4 => array("Student40", "Student41", "Student42", "Student43"));
/* 計(jì)算C(a,1) * C(b, 1) * ... * C(n, 1)的值 */
$CombineCount = 1;
foreach($CombinList as $Key => $Value)
{
$CombineCount *= count($Value);
}
$RepeatTime = $CombineCount;
foreach($CombinList as $ClassNo => $StudentList)
{
// $StudentList中的元素在拆分成組合后縱向出現(xiàn)的最大重復(fù)次數(shù)
$RepeatTime = $RepeatTime / count($StudentList);
$StartPosition = 1;
// 開(kāi)始對(duì)每個(gè)班級(jí)的學(xué)生進(jìn)行循環(huán)
foreach($StudentList as $Student)
{
$TempStartPosition = $StartPosition;
$SpaceCount = $CombineCount / count($StudentList) / $RepeatTime;
for($J = 1; $J <= $SpaceCount; $J ++)
{
for($I = 0; $I < $RepeatTime; $I ++)
{
$Result[$TempStartPosition + $I][$ClassNo] = $Student;
}
$TempStartPosition += $RepeatTime * count($StudentList);
}
$StartPosition += $RepeatTime;
}
}
/* 打印結(jié)果 */
echo "<pre>";
print_r($Result);
?>
復(fù)制代碼 代碼如下:
<?php
/**
* 要解決的數(shù)學(xué)問(wèn)題 :算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
*
* 要解決的實(shí)際問(wèn)題樣例:某年級(jí)有m個(gè)班級(jí),每個(gè)班的人數(shù)不同,現(xiàn)在要從每個(gè)班里抽選一個(gè)人組成一個(gè)小組,
* 由該小組來(lái)代表該年級(jí)參加學(xué)校的某次活動(dòng),請(qǐng)給出所有可能的組合
*/
/* ################################### 開(kāi)始計(jì)算 ################################### */
/**
* 需要進(jìn)行排列組合的數(shù)組
*
* 數(shù)組說(shuō)明:該數(shù)組是一個(gè)二維數(shù)組,第一維索引代表班級(jí)編號(hào),第二維索引代表學(xué)生編號(hào)
*/
$CombinList = array(1 => array("Student10", "Student11"),
2 => array("Student20", "Student21", "Student22"),
3 => array("Student30"),
4 => array("Student40", "Student41", "Student42", "Student43"));
/* 計(jì)算C(a,1) * C(b, 1) * ... * C(n, 1)的值 */
$CombineCount = 1;
foreach($CombinList as $Key => $Value)
{
$CombineCount *= count($Value);
}
$RepeatTime = $CombineCount;
foreach($CombinList as $ClassNo => $StudentList)
{
// $StudentList中的元素在拆分成組合后縱向出現(xiàn)的最大重復(fù)次數(shù)
$RepeatTime = $RepeatTime / count($StudentList);
$StartPosition = 1;
// 開(kāi)始對(duì)每個(gè)班級(jí)的學(xué)生進(jìn)行循環(huán)
foreach($StudentList as $Student)
{
$TempStartPosition = $StartPosition;
$SpaceCount = $CombineCount / count($StudentList) / $RepeatTime;
for($J = 1; $J <= $SpaceCount; $J ++)
{
for($I = 0; $I < $RepeatTime; $I ++)
{
$Result[$TempStartPosition + $I][$ClassNo] = $Student;
}
$TempStartPosition += $RepeatTime * count($StudentList);
}
$StartPosition += $RepeatTime;
}
}
/* 打印結(jié)果 */
echo "<pre>";
print_r($Result);
?>
您可能感興趣的文章:
- PHP實(shí)現(xiàn)的簡(jiǎn)單排列組合算法應(yīng)用示例
- php全排列遞歸算法代碼
- 淺談PHP的排列組合(如輸入a,b,c 輸出他們的全部組合)
- php通過(guò)排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法
- php求數(shù)組全排列,元素所有組合的方法總結(jié)
- PHP輸出多個(gè)元素的排列或組合的方法
- php求數(shù)組全排列,元素所有組合的方法
- PHP實(shí)現(xiàn)基于圖的深度優(yōu)先遍歷輸出1,2,3...n的全排列功能
- PHP實(shí)現(xiàn)字符串的全排列詳解
- php實(shí)現(xiàn)的生成排列算法示例
相關(guān)文章
CodeIgniter中實(shí)現(xiàn)泛域名解析
這篇文章主要介紹了CodeIgniter中實(shí)現(xiàn)泛域名解析的方法,需要的朋友可以參考下2014-07-07
PHP array_reduce()函數(shù)的應(yīng)用解析
這篇文章主要介紹了PHP array_reduce()的應(yīng)用,本文通過(guò)代碼舉例給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-10-10
ThinkPHP通過(guò)AJAX返回JSON的兩種實(shí)現(xiàn)方法
這篇文章主要介紹了ThinkPHP通過(guò)AJAX返回JSON的兩種實(shí)現(xiàn)方法,分析了ThinkPHP中內(nèi)置的ajaxReturn函數(shù)的用法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12
yii2 resetful 授權(quán)驗(yàn)證詳解
這篇文章主要介紹了yii2 resetful 授權(quán)驗(yàn)證詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05
實(shí)用的簡(jiǎn)單PHP分頁(yè)集合包括使用方法
收集了三個(gè)PHP分頁(yè)方法,總會(huì)有一個(gè)適合你用的。2013-10-10
php結(jié)合GD庫(kù)簡(jiǎn)單實(shí)現(xiàn)驗(yàn)證碼的示例代碼
這篇文章主要介紹了php結(jié)合GD庫(kù)簡(jiǎn)單實(shí)現(xiàn)驗(yàn)證碼的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01

