使用php計(jì)算排列組合的方法
更新時(shí)間:2013年11月13日 09:48:33 作者:
本文用PHP要解決的數(shù)學(xué)問題是算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
前些天因?yàn)闃I(yè)務(wù)需要寫了一段計(jì)算排列組合的代碼,今天整理了一下,以備后用
<?php
/**
* 要解決的數(shù)學(xué)問題 :算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
*
* 要解決的實(shí)際問題樣例:某年級有m個(gè)班級,每個(gè)班的人數(shù)不同,現(xiàn)在要從每個(gè)班里抽選一個(gè)人組成一個(gè)小組,
* 由該小組來代表該年級參加學(xué)校的某次活動,請給出所有可能的組合
*/
/* ################################### 開始計(jì)算 ################################### */
/**
* 需要進(jìn)行排列組合的數(shù)組
*
* 數(shù)組說明:該數(shù)組是一個(gè)二維數(shù)組,第一維索引代表班級編號,第二維索引代表學(xué)生編號
*/
$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;
// 開始對每個(gè)班級的學(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é)問題 :算出C(a,1) * C(b, 1) * ... * C(n, 1)的組合情況,其中C(n, 1)代表從n個(gè)元素里任意取一個(gè)元素
*
* 要解決的實(shí)際問題樣例:某年級有m個(gè)班級,每個(gè)班的人數(shù)不同,現(xiàn)在要從每個(gè)班里抽選一個(gè)人組成一個(gè)小組,
* 由該小組來代表該年級參加學(xué)校的某次活動,請給出所有可能的組合
*/
/* ################################### 開始計(jì)算 ################################### */
/**
* 需要進(jìn)行排列組合的數(shù)組
*
* 數(shù)組說明:該數(shù)組是一個(gè)二維數(shù)組,第一維索引代表班級編號,第二維索引代表學(xué)生編號
*/
$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;
// 開始對每個(gè)班級的學(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);
?>
您可能感興趣的文章:
相關(guān)文章
php file_get_contents抓取Gzip網(wǎng)頁亂碼的三種解決方法
用 file_get_contents() 函數(shù)抓取網(wǎng)頁會發(fā)生亂碼現(xiàn)象。有兩個(gè)原因會導(dǎo)致亂碼,一個(gè)是編碼問題,一個(gè)是目標(biāo)頁面開了Gzip,下面說的就是開了Gzip功能如何才能不亂碼的方法2013-11-11Yii2框架實(shí)現(xiàn)利用mpdf創(chuàng)建pdf文件功能示例
這篇文章主要介紹了Yii2框架實(shí)現(xiàn)利用mpdf創(chuàng)建pdf文件功能,結(jié)合實(shí)例形式分析了mpdf的下載、安裝及結(jié)合Yii2框架創(chuàng)建pdf文件的相關(guān)操作技巧,需要的朋友可以參考下2019-02-02微信開發(fā)之網(wǎng)頁授權(quán)獲取用戶信息(二)
本文給大家闡述的微信開發(fā)基于yii2.0框架,對微信開發(fā)之網(wǎng)頁授權(quán)獲取用戶信息相關(guān)知識感興趣的朋友通過本文學(xué)習(xí)吧2016-01-01基于php偽靜態(tài)的實(shí)現(xiàn)詳細(xì)介紹
本篇文章介紹了,基于php偽靜態(tài)的實(shí)現(xiàn)詳細(xì)分析。需要的朋友參考下2013-04-04php 文件上傳至OSS及刪除遠(yuǎn)程阿里云OSS文件
今天給大家介紹php 文件上傳至OSS及刪除遠(yuǎn)程阿里云OSS文件的方法,在刪除文件的時(shí)候大家記住千萬不要帶域名,具體操作示例參考下本文2021-07-07PHP jQuery表單,帶驗(yàn)證具體實(shí)現(xiàn)方法
這篇文章主要介紹了PHP jQuery表單,帶驗(yàn)證具體實(shí)現(xiàn)方法,需要的朋友可以參考下2014-02-02解決laravel 5.1報(bào)錯(cuò):No supported encrypter found的辦法
這篇文章主要給大家介紹了關(guān)于解決laravel 5.1報(bào)錯(cuò):No supported encrypter found的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考借鑒,下面來一起看看吧。2017-06-06