最近遇到了一个算法题,要求对一个key:value这样的数组,根据value值对对key进行排序(这里的value值可以指多行),一个酒店的评分系统的逻辑。
名称 卫生 用户体验 安全性
A x1 y1 z1
B x2 y2 z2
... ... ... ...
类似于上面的这样子的,然后先对卫生排序,卫生排完,选出卫生排序得出的前三名,选择前面选出的前三民,根据用户体验排序,选出用户体验前两名,根据安全性排序,选出安全性的第一名。
最后输出这个第一名。
感觉其实都差不多,但是资料也查过,map函数也看了,但是还是理解不了到底该怎么搞,求大佬赐教一波。(ps:明明感觉自己算法算不上差啊,可是每次遇到稍微复杂一点的算法就被搞晕了,刚入前端坑不久,基本的js相关的代码都撸过一遍),求大佬解惑。
雷雷
首先你这个是题目还是项目? 如果是真实项目,你可以用上
lodash
的sortBy
对列表中的对象进行排序。假设你的酒店列表模型简化为:
现在需求是把list中的对象先按a排序,再按b排序,再按c排序。 实现起来就是:
如果分数是越大越好,那么应该是逆序
像题中所说的,要取出3,2, 1名,那么不需要每次都对全部结果排。
如果是面试题,还需要完成
sortBy
这个函数, 可以简单利用Array#sort
实现:要注意的是:
sortBy
要实现成稳定排序, 即两个分数一致的对象,排序前后相对位置要保持不变。当然直接使用上
Array#sort(func)
这个函数也是很方便的。