用php求n个分数的和,php关于数组n个随机数分成x组,使每组值相近的算法

主要原理是,将数组从大到小排序,数组1先取数取第一个,数组2第2取第2个,以此类推

取完第一次数组之后,判断下数组1,数组2,进行一次排序,将数据最大的排前面(理论上来说,数组1数据最大,因为从大到小排序)

当数组1是最大时,让数组1取倒数第一个值(最小值),数组2取倒数第2个值,以此类推

这时候,数组1取得是最小,数组2取的是第二小,会让总数开始慢慢的接近,以此类推

下面是一个n个数字分2组的实例代码,分x组的可以自己写咯<?php

function group_arr($arr_count, $max_num)

{

$arr = array();

for ($i = 0; $i 

$arr[] = mt_rand(0, $max_num);

}

rsort($arr);

//var_dump($arr);

//从大到小排序一下

$total = array_sum($arr);

//var_dump($total);

$arr1     = array();

$arr2     = array();

$arr1_sum = 0;

$arr2_sum = 0;

$mean     = $total / 2;//平均数

$arr_arr = $arr;

for ($i = 0; $i 

//        var_dump($arr_arr);

if ($arr1_sum > $arr2_sum) {

$arr1_sum += $arr1[] = $arr_arr[count($arr_arr)-1];

array_splice($arr_arr,-1,1);//数组删除元素重排

$arr2_sum += $arr2[] = $arr_arr[count($arr_arr)-1];

array_splice($arr_arr,-1,1);//数组重排

} else {

$arr1_sum += $arr1[] = $arr_arr[0];

array_splice($arr_arr,0,1);//数组重排

$arr2_sum += $arr2[] = $arr_arr[0];

array_splice($arr_arr,0,1);//数组重排

}

}

echo '
数组:' . json_encode($arr);

echo '
总数:' . array_sum($arr);

echo '
arr1数组:' . json_encode($arr1);

echo '
arr1:' . array_sum($arr1);

echo '
arr2数组:' . json_encode($arr2);

echo '
arr2:' . array_sum($arr2);

echo '
arr总数:' .( array_sum($arr1)+array_sum($arr2));

}

group_arr(10, 100);

注意,这个算法思路取到的不一定是最接近的值,只能说是相对接近并且数字越多精度越高,以下是10个100随机数分2组的测试图

79b53707518e12b3a9aca0817e432375.png

d8ddbc8cc2b1d6436526d4ddf1ceefc6.png

610580f7f350e3160457d770b6c80500.png

16fbf7684237ebdad7afd0186535f97f.png

本文为仙士可原创文章,转载无需和我联系,但请注明来自仙士可博客www.php20.cn

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值