华为od机试C卷【推荐多样性】

这篇博客主要介绍了华为在线开发者(OD)测试中的一道算法题,要求实现推荐多样性的策略。该策略涉及从多个列表中按特定顺序选择元素填充窗口,确保每个列表的元素尽可能平均分配。博客提供了输入输出描述、示例和解题思路,但未给出具体代码实现。
摘要由CSDN通过智能技术生成

目录

题目

思路

code


题目

推荐多样性需要从多个列表中选择元素,一次性要返回N屏数据(窗口数量),每屏展示K个元素(窗口大小),选择策略

1.各个列表元素需要做穿插处理,即先从第一个列表中为每屏选择一元素,再从第二个列表中为每屏选择一个元素,依次类推

2.每个列表的元素尽量均分为N份,如果不够N个,也要全部分配完,比如下面的例子:

(1)从第一个列表中选择4条0 1 2 3,分别放到4个窗口中

(2)从第二个列表中选择4条10 11 12 13,分别放到4个窗口中

(3)从第三个列表中选择4条20 21 22 23,分别放到4个窗口

(4)再从第一个列表中选择4条4 5 6 7,分别放到4个窗口中

(5)再从第一个列表中选择,由于数量不足4条,取剩下的2条,放到窗1和窗口2

(6)再从第二个列表中选择,由于数量不足4条并且总的元素数达到窗口要求,取18 19放到窗口3和窗口4

输入描述

第一行输入为N,表示需要输出的窗口数量,取值范围[1,10]

第二行输入为K,表示每个窗口需要的元素数量Q,取值范用[1,100].之后

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值