用PHP怎样实现权重算法,有什么优势
Admin 2022-07-07 群英技术资讯 886 次浏览
今天就跟大家聊聊有关“用PHP怎样实现权重算法,有什么优势”的内容,可能很多人都不太了解,为了让大家认识和更进一步的了解,小编给大家总结了以下内容,希望这篇“用PHP怎样实现权重算法,有什么优势”文章能对大家有帮助。本文实例讲述了PHP实现的权重算法。分享给大家供大家参考,具体如下:
假设有数据:
$data = array ( array ( 'id' => 1, 'name' => '张三', 'weight' => 5 ), array ( 'id' => 2, 'name' => '王五', 'weight' => 10 ), array ( 'id' => 3, 'name' => '李四', 'weight' => 15 ), );
要随机取出其中一条,并且不是完全随机,而是根据其中weight的数值,按照数值越大,几率越高的规律取出。
以前写过一些权重算法,可是都不完美,要么数据量有限制,要么weight之和必须等于一个指定的数等等,都不完善。
今天突发奇想,写了一套完美的权重算法,该算法有如下优势:
1. 支持无限多个数据
2. weight值之和任意
3. 不存在两个weight值一样时无法平均分配的bug
算法如下:
$data = array (
array (
'id' => 1,
'name' => '张三',
'weight' => 5
),
array (
'id' => 2,
'name' => '王五',
'weight' => 10
),
array (
'id' => 3,
'name' => '李四',
'weight' => 15
),
);
$weight = 0;
$tempdata = array ();
foreach ($data as $one) {
$weight += $one['weight'];
for ($i = 0; $i < $one['weight']; $i++) {
$tempdata[] = $one;
}
}
$use = rand(0, $weight -1);
$one = $tempdata[$use];
var_dump($one);
运行结果:
array(3) {
["id"]=>
int(2)
["name"]=>
string(4) "王五"
["weight"]=>
int(10)
}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
本文章向大家介绍php7连接Sqlserver的方法,主要包括php7.2连接Sqlserver使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
php中array_fill函数:1、用于使用给定索引,从给定索引中填充数组中的n个元素;2、语法array_fill(index,number,value);3、参数index、number和value;4、返回值,返回填充的数组。
用一个中介对象来封装一系列的对象交互,使各对象不需要显式地相互引用从而使其耦合松散,而且可以独立地改变它们之间的交互,那要怎么独立改变php设计模式 Mediator (中介者模式)的交互呢?
php中 __clone的使用:1、用于对象复制。对象复制通过clone关键字来完成。2、__clone()方法不需要任何参数。3、在复制的同时,目标对象的某些属性与源对象的不同,可以在类里面定义一个__clone()方法。
本篇文章给大家介绍一下PHP7.x中各个版本的新特性。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008