推荐多样性 - 华为OD统一考试(C卷)

OD统一考试(C卷)

分值: 200分

题解: Java / Python / C++

alt

题目描述

推荐多样性需要从多个列表中选择元素,一次性要返回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

img

输入描述

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

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

之后的行数不定(行数取值范围[1,10]),表示每个列表输出的元素列表。元素之间以空格分隔,已经过排序处理,每个列表输出的元素数量取值范围[1,100]

输出描述

输出元素列表,元素数量=窗口数量*窗口大小,元素之间以空格分隔,多个窗口合并为一个列表输出,参考样例:

先输出窗口1的元素列表,再输出窗口2的元素列表,再输出窗口3的元素列表,最后输出窗口4的元素列表

补充说明

  1. 每个列表会保证元素数量满足窗口要求,不需要考虑元素不足情况

  2. 每个列表的元素已去重,不需要考虑元素重复情况

  3. 每个列表的元素列表均不为空,不需要考虑列表为空情况

  4. 每个列表的元素列表已经过排序处理,输出结果要保证不改变同一个列表的元素顺序

  5. 每个列表的元素数量可能是不同的

示例1

输入:
4
7
0 1 2 3 4 5 6 7 8 9
10 11 12 13 14 15 16 17 18 19
20 21 22 23 24 25 26 27 28 29

输出:
0 10 20 4 14 24 8 1 11 21 5 15 25 9 2 12 22 6 16 26 18 3 13 23 7 17 27 19

题解

这道题目是一个简单的数据处理问题,需要根据输入的窗口数量、窗口大小以及多个列表中的元素,按照规定的选择策略进行元素的选取和输出。下面是解题思路和代码描述:

解题思路

  • 首先读取输入的窗口数量和窗口大小,然后读取多个列表的元素。
  • 根据窗口数量和窗口大小,依次从每个列表中选择元素并放入对应的窗口中,按照规定的选择策略进行穿插处理。
  • 最后输出选取的元素列表,合并多个窗口的元素为一个列表输出。

Java

import java.util.*;

/**
 * @author code5bug
 */
public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt(), k = in.nextInt();
        in.nextLine();  // 消耗掉换行符号

        // 读入列表元素
        List<Queue<Integer>> lq = new ArrayList<>();
        while (in.hasNext()) {
            int[] nums = Arrays.stream(in.nextLine().split(" "))
                    .mapToInt(Integer::parseInt).toArray();

            Queue<Integer> queue = new ArrayDeque<>();
            for (int num : nums) queue.add(num);
            lq.add(queue);
        }

        // n 个窗口数据
        Queue<Integer>[] windows = new Queue[n];
        Arrays.setAll(windows, i -> new ArrayDeque<>());

        // 列表元素穿插放入 n 个窗口中
        int qidx = 0;  // 当前处理到的列表索引位置
        while (k-- > 0) {
            for (int i = 0; i < n; i++) {
                Queue<Integer> queue = lq.get(qidx);
                // 直到找到有数据的列表
                while (queue.isEmpty()) queue = lq.get((++qidx) % lq.size());

                windows[i].add(queue.poll());
            }
            qidx = (qidx + 1) % lq.size();
        }

        // 拼接结果
        StringBuilder rs = new StringBuilder();
        for (int i = 0; i < windows.length; i++) {
            while (!windows[i].isEmpty()) {
                rs.append(windows[i].poll()).append(" ");
            }
        }

        System.out.println(rs.toString());
    }
}

Python

from collections import deque

n, k = int(input()), int(input())
input_lists = []

# 读入列表元素
while True:
    try:
        input_lists.append(deque(input().split()))
    except EOFError:
        break

idx = 0  # 当前处理到的列表索引位置
windows = [list() for _ in range(n)]    # n 个窗口数据

# 列表元素穿插放入 n 个窗口中
for _ in range(k):
    for i in range(n):
        while not input_lists[idx]:
            idx = (idx + 1) % len(input_lists)

        windows[i].append(input_lists[idx].popleft())
    idx = (idx + 1) % len(input_lists)

# 拼接结果
ls = [' '.join(window) for window in windows]
print(' '.join(ls))

C++

#include <bits/stdc++.h>
using namespace std;

int main()
{
    int n, k;
    cin >> n >> k;
    cin.ignore();   // 消耗掉换行符号

    // 读入列表元素
    vector<queue<int>> lq;
    string             line;
    while (getline(cin, line)) {
        istringstream iss(line);
        queue<int>    queue;
        int           num;
        while (iss >> num) {
            queue.push(num);
        }
        lq.push_back(queue);
    }

    // n 个窗口数据
    vector<queue<int>> windows(n);

    // 列表元素穿插放入 n 个窗口中
    int qidx = 0;   // 当前处理到的列表索引位置
    while (k-- > 0) {
        for (int i = 0; i < n; i++) {
            // 直到找到有数据的列表
            while (lq[qidx].empty()) {
                qidx = (qidx + 1) % lq.size();
            }

            windows[i].push(lq[qidx].front());
            lq[qidx].pop();
        }
        qidx = (qidx + 1) % lq.size();
    }

    // 拼接结果
    stringstream rs;
    for (int i = 0; i < windows.size(); i++) {
        while (!windows[i].empty()) {
            rs << windows[i].front() << " ";
            windows[i].pop();
        }
    }

    cout << rs.str() << endl;
    return 0;
}

有考友通过专栏已经快速通过机考✍,都是原题哦, 🎁🎁🎁 立即订阅

希望这个专栏不仅能帮您成功通过华为机试,还能让您熟练掌握算法。

🙏整理题解不易, 如果有帮助到您,请给点个赞 ‍❤️‍ 和收藏 ⭐,让更多的人看到。🙏🙏🙏

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/490253.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

深度强化学习(十)(TRPO)

深度强化学习&#xff08;十&#xff09;&#xff08;TRPO与PPO&#xff09; 一.信赖域方法 原问题&#xff1a; maxmize J ( θ ) \text{maxmize} \qquad\qquad J(\theta) maxmizeJ(θ) J J J是个很复杂的函数&#xff0c;我们甚至可能不知道 J J J 的解析表达式&#xff…

【Entity Framework】 EF三种开发模式

【Entity Framework】 EF三种开发模式 文章目录 【Entity Framework】 EF三种开发模式一、概述二、DataBase First2.1 DataBase First简介2.2 DataBase First应用步骤2.3 DataBase First总结 三、Model First3.1 Model First简介3.2 Model First实现步骤 四、Code First4.1 Cod…

YOLOv9有效改进专栏汇总|未来更新卷积、主干、检测头注意力机制、特征融合方式等创新![2024/3/23]

​ 专栏介绍&#xff1a;YOLOv9改进系列 | 包含深度学习最新创新&#xff0c;助力高效涨点&#xff01;&#xff01;&#xff01; 专栏介绍 YOLOv9作为最新的YOLO系列模型&#xff0c;对于做目标检测的同学是必不可少的。本专栏将针对2024年最新推出的YOLOv9检测模型&#xff0…

一文看懂,如何精细化地进行跨域文件管控

随着企业规模的扩大和分支机构的增多&#xff0c;会出现不同地理位置、组织机构或网络安全域之间进行文件交换的场景。 像很多金融机构在全国或全球范围内会设立不同的分支机构和办事处&#xff0c;因此会存在不同组织机构之间的数据流转&#xff0c;即跨域文件传输。跨域文件传…

知识分享|视频号带货需要满足什么硬性条件?

视频号带货作为一种新兴的电商模式&#xff0c;已经逐渐受到越来越多人的关注。然而&#xff0c;想要在这一领域取得成功&#xff0c;并不是一件轻松的事情。除了需要具备一定的营销技巧和内容创作能力外&#xff0c;还有一些硬性条件必须得到满足。 首先&#xff0c;视频号带货…

GIMP - GNU 图像处理程序 - 中文版

GIMP - GNU 图像处理程序 - 中文版 1. Edit -> Preferences -> Interface2. Chinese [zh_CN]3. 重启 GIMP 即可References 1. Edit -> Preferences -> Interface 2. Chinese [zh_CN] 3. 重启 GIMP 即可 References [1] Yongqiang Cheng, https://yongqiang.blog.…

Xcode Launching “XXX“ is taking longer than expected

文章目录 1.问题2.如何进入iOS DeviceSupport目录3.解决方法4.参考博客 1.问题 LLDB is likely reading from device memory to resolve symbols 2.如何进入iOS DeviceSupport目录 3.解决方法 进入iOS DeviceSupport目录&#xff0c;删除该真机对应的架构文件&#xff08;比如…

谁再问你数据库三范式,这篇文章甩给他!!!

前几天有粉丝私信说面试被问到了数据库三范式&#xff08;面试问这种的不去也好&#xff09;&#xff0c;今天我们就来聊聊。在数据库设计的过程中&#xff0c;为了确保数据的准确性和完整性&#xff0c;我们通常遵循一定的规则和标准&#xff0c;其中最为人所熟知的便是“数据…

C++模版(基础)

目录 C泛型编程思想 C模版 模版介绍 模版使用 函数模版 函数模版基础语法 函数模版原理 函数模版实例化 模版参数匹配规则 类模版 类模版基础语法 C泛型编程思想 泛型编程&#xff1a;编写与类型无关的通用代码&#xff0c;是代码复用的一种手段。 模板是泛型编程…

优化选址问题 | 基于和声搜索算法求解基站选址问题含Matlab源码

目录 问题代码问题 和声搜索算法(Harmony Search, HS)是一种模拟音乐创作过程中乐师们凭借自己的记忆,通过反复调整各乐器的音调,直至达到最美和声状态为启发,通过反复调整解向量的各分量来寻求全局最优解的智能优化算法。 下面是一个基于和声搜索算法求解基站选址问题的…

大创项目推荐 基于图像识别的跌倒检测算法

前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 基于图像识别的跌倒检测算法 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff0c;学长非常推荐&#xff01; &#x1f9ff; 更多资料, 项目分享&#xff1a; https://gitee.com/dancheng-senior/…

MySQL数据库的日志管理以及备份和恢复

目录 1、日志管理 2、查询日志 3、数据备份的重要性 4、数据库备份的分类 4.1物理备份 4.2逻辑备份&#xff1a; 4.3完全备份 5、常见的备份方法 6、MySQL完全备份 6.1MySQL完全备份优缺点 6.2数据库完全备份分类 6.2.1物理冷备份与恢复 6.2.2mysqldump备份…

什么是回归测试?

今天看看回归测试的基本概念。 什么是回归测试? 回归测试被定义为一种软件测试&#xff0c;以确认最近的程序或代码更改没有对现有功能产生不利影响。回归测试只是对已经执行的测试用例的全部或部分选择&#xff0c;重新执行这些用例以确保现有功能正常工作。 进行此测试是…

MYSQL高级语句(一)

目录 一、常用查询 1、order by 按关键字排序 1.升序排序 2.降序排序 3.结合where进行条件过滤再排序 4.多字段排序 2、区间判断及查询不重复记录 1. and / or 且与或的使用 2.嵌套、多条件使用 3.distinct 查询不重复记录 3、GROUP BY 对结果进行分组 4、Li…

就业班 第二阶段 2401--3.25 day5 mycat读写分离

[TOC] 启动并更改临时密码 [rootmysql1~]# systemctl start mysqld && passwdgrep password /var/log/mysqld.log | awk END{ print $NF} && mysqladmin -p"$passwd" password Qwer123..; MyCAT读写分离 Mycat 是一个开源的数据库系统&#xff0c;但…

【Node.js】WebSockets

概述 WebSockets是一种在浏览器和服务器之间建立持久连接的协议&#xff0c;它允许服务器主动推送数据给客户端&#xff0c;并且在客户端和服务器之间实现双向通信。 建立连接&#xff1a;客户端通过在JavaScript代码中使用WebSocket对象来建立WebSockets连接。例如&#xff1…

安达发|电子产品制造企业APS生产排程软件

在电子脉动的世界中&#xff0c;时间是芯片上的电流&#xff0c;效率是电路板上的速度。在这个时代&#xff0c;每一微秒都蕴藏着无限可能&#xff0c;每一决策都关乎着企业的生死存亡。APS生产排程软件&#xff0c;是您的电子制造帝国中的智慧大脑&#xff0c;以卓越的创造力&…

C++手撕AVL树

文章目录 AVL树概念 节点插入右单旋左右双旋 验证AVL树AVL树的性能 AVL树 之前我们讲了二叉搜索树的相关内容&#xff0c;但是也了解到二叉搜索树有其自身的缺陷&#xff0c;就是当插入的元素有序或者接近有序&#xff0c;退化成单支树的时候&#xff0c;他的时间复杂度就会退…

AIGC: 4 IT从业者如何构建自己的AI知识体系

图片是我使用dall.e模型生成的图片&#xff0c; 提示词&#xff1a; 程序员系统学习OpenAI开发者平台系统学习。 我按照SCQA模型&#xff0c;来开始今天的内容。 S 场景 今天是2024年3月23日&#xff0c;我在深圳&#xff0c;从事IT行业&#xff0c;每个人从事的行业各不相…

redis启动后无法被外部主机连接

目录 一、场景二、连接异常三、排查四、原因五、解决 一、场景 1、CentOS安装redis后&#xff0c;外部主机无法连接到redis 二、连接异常 1、RedisDesktopManager无法连接 2、使用telnet命令测试6379端口是否能正常访问 三、排查 1、redis服务是否启动 四、原因 从以下信息…