微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

用户 一对多分配 PHP

我这边有一个业务需求,就是有两种用户类别(第二种类别用户数远超第一类用户),然后需要根据他们所选的偏好和地区来进行匹配。

比如说A类用户:他们可以多选偏好,并且可以选择多个城市,例如下方示例的 userA1, userA2,

A类用户示例如下所示:

{

label:'userA1',

type:1,

like:['1', '4', '11'],

like2:['3','14','15'],

city:['1','2']

},

{

label:'userA2',

type:1,

like:['1', '11'],

like2:['3','13'],

city:['2', '3']

},

...

B类用户:他们只能选择单选偏好和城市,比如 userB1, userB2,

B类用户示例如下所示:

{

label:'userB1',

type:2,

like:"1",

like2:"3"

city:"1"

},

{

label:'userB2',

type:2,

like:"4",

like2:"7"

city:"6"

},

...

分配的时候就需要根据他们所选择的偏好来进行匹配,匹配规则:

1. 双方用户必须匹配 city 字段;

2. 优先双方匹配 like 字段,如果B类用户的 like 字段没有匹配到A类用户,则使用A类用户的 like2 字段来匹配,如果还没有就轮空;

3. 每一个A类用户最多不能匹配超过5个B类用户,如果B类用户实在多,所有匹配的A类用户都匹配了5个时,继续1、2步骤进行分配直到所有B类用户分配完成。

我小伙伴的一个需求,稍微做了一下模糊处理,因为我主力语言是 Js, PHP 并不了解多少,所以提供了几个解决方案都被他否决了。

所以厚着脸皮来社区问问是不是有大佬能给个思路....

他觉得困难的地方就是A类用户三个属性都是多选的。

我说让他把A类用户按照 like 分组,添加 count 属性并以此排序,然后用B类用户一个一个去分配,如果分配成功就把对应的A类用户 count++,跑完全部 B类用户 不就好了。

但是他说不行,最后第三条规则他处理不来,最多做到不限数量分配,但是我没有 Get 到为啥不行的点,可能 Js 的编程思路和 PHP 的有点差异吧...

也许是可能会出现某一个A用户选择了全部偏好然后出现一柱擎天的情况???

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐