笔试:4.6美团笔试(硬件开发方向)

二十道选择两道算法题。

选择就不说了,硬件方面目前了解较少。

两道算法题都过了,第一题很简单没有什么好讲的。

第二题看着题目以为会很复杂,没想到一遍过。

小美有一个由 n 个互不相等的正整数构成的数组 a,但她一不小心把 a 弄丢了,他想要重新找到 a。

好在她并不是一无所有,她还记得以下有关 a 的信息:

1. 他完全记得数组 b 的样子,并且 b 是数组 a 删除了某个 a_i 后,剩余的部分做前缀和并打乱的结果。
2. 他完全记得数组 c 的样子,并且 c 是数组 a 删除了某个 a_j 后,剩余的部分做前缀和并打乱的结果。
(保证两次删除的 a_i 和 a_j 不是同一个 a 中的元素)。

请你帮她还原出 a 数组吧。

补充:前缀和指一个数组的某下标之前的所有数组元素的和(包含其自身)。

输入描述
输入包含三行。
第一行一个正整数 n\ (3 \leq n \leq 10 ^ 5),表示数组 a 的长度。
第二行 n - 1 个正整数 b_i\ (1 \leq b_i \leq 10 ^ {14}),表示题中所述数组 b。
第二行 n - 1 个正整数 c_i\ (1 \leq c_i \leq 10 ^ {14}),表示题中所述数组 c。
(输入保证有唯一解)

输出描述
输出一行 n 个整数,表示你还原出的 a 数组。
4
8 18 14
15 9 1
输出

1 8 6 4
说明
b 数组是 a 中删除了 a[1] 后,求前缀和,再打乱得到的。
c 数组是 a 中删除了 a[4] 后,求前缀和,再打乱得到的。

思路:所谓前缀和,一定是递增的,所以题目中把打乱了完全没有用,通过排序就可以找回打乱前的数组。然后从后往前用当前前缀和减去前一个前缀和即可得到当前数字。两次操作后我们就得到了b和c的原始数组,即删除了一个a中数字的数组。

注意:此时的b,c数组和a的顺序完全一样,只是删除了一个数字。利用这一点我们才可以按照正确的顺序求出a数组。

接下来只需要找到被删除的那个数字并且插入原来数组即可。

接下来使用两个指针指向b,c,如果指针值相等则判断下一个,如果不等则说明在当前位置b,c中有一个删除了a中的一个数字。在删除的数组中,当前指针所指的数据必然为另一个数组中下一个数据(关于这点下面详细解释),将另一个数组中的数据插入删除的数组即可。举个例子1,2,3,4,5,删除2、4,自己想一想就知道了。

关于上面的解释:题目说保证有唯一解,所以删除的两个数字必然不可能连续,如果连续,则我们不可能知道这两个数字在原数组中的顺序,不知道谁先谁后。所以如果发现当前数组中被删了一个数字,那么下一个一定没有被删,两数组中一定都有该数字,只需要通过一个判断与下一个数字比较看哪个数组被删除了即可。

#include<bits/stdc++.h>
using namespace std;int main()
{int n;cin >> n;vector<long long>a(n), b(n - 1), c(n - 1);for (int i = 0; i < n - 1; i++){cin >> b[i];}for (int i = 0; i < n - 1; i++){cin >> c[i];}sort(b.begin(), b.end());sort(c.begin(), c.end());for (int i = n - 2; i >= 1; i--){b[i] = b[i] - b[i - 1];c[i] = c[i] - c[i - 1];}int pb = 0, pc = 0;while (pb < n - 1 && pc < n - 1){if (b[pb] == c[pc]){pb++;pc++;continue;}if (b[pb + 1] == c[pc]){c.insert(c.begin() + pc, b[pb]);break;}else if (c[pc + 1] == b[pb]){b.insert(b.begin() + pc, c[pc]);break;}else{}}if (b.size() == n){for (int i = 0; i < n; i++){cout << b[i] << ' ';}}else if (c.size() == 0){for (int i = 0; i < n; i++){cout << c[i] << ' ';}}else{}
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Three 之 three.js (webgl)GLSL-Card 中文手册相关知识

Three 之 three.js &#xff08;webgl&#xff09;GLSL-Card 中文手册相关知识 目录 Three 之 three.js &#xff08;webgl&#xff09;GLSL-Card 中文手册相关知识 一、简单介绍 二、GLSL 中文手册 1、基本类型 2、基本结构和数组 3、向量的分量访问 4、运算符 5、基础…

<c++基础(5)>整数溢出

整数溢出 在工程中遇到问题&#xff0c;两个int类型加减结果赋值给double类型时提示溢出风险&#xff1a; //sum和sumb都是int类型&#xff0c; double a double(sum - sumB);这里发生了整数溢出&#xff0c;整数溢出是指当计算结果超出了整数类型所能表示的范围时发生的情况…

南京观海微电子---Vitis HLS设计流程(实例演示)——Vitis HLS教程

1. 前言 课时2我们介绍了Vitis HLS的设计流程&#xff0c;如下图所示&#xff1a; 算法或软件的设计和仿真都基于C/C&#xff0c;通过HLS平台导出打包好的IP RTL代码&#xff0c;最后将该打包的IP加入到主工程使用。 本课时&#xff0c;我们通过一个具体的实例&#xff0c;演示…

Dapr(三) Dapr核心组件的使用一

结合前两期 Dapr(一) 基于云原生了解Dapr(Dapr(一) 基于云原生了解Dapr-CSDN博客) Dapr(二) 分布式应用运行时搭建及服务调用(Dapr(二) 分布式应用运行时搭建及服务调用-CSDN博客) 下篇推出dapr服务注册与发现&#xff0c;dapr组件绑定&#xff0c;dapr Actor功能。 目录 1.…

中颖51芯片学习2. IO端口操作

一、SH79F9476 I/O端口介绍 1. 特性 SH79F9476提供了30/26位可编程双向 I/O 端口&#xff1b;端口数据在寄存器Px中&#xff1b;端口控制寄存器PxCRy是控制端口作为输入还是输出&#xff1b;端口作为输入时&#xff0c;每个I/O端口均带有PxPCRy控制的内部上拉电阻。有些I/O引…

超详细!211页网络协议与管理,看完终于明白了(建议收藏)

与其说计算机改变了世界&#xff0c;不如说是计算机网络改变了世界。作为计算机网络通信实体之间的语言&#xff0c;网络通信协议对计算机正常通信起着极大的作用。 那么到底什么是网络协议与管理呢&#xff1f;今天给大家分享一份211页网络协议与管理文档&#xff0c;包含概念…

碧桂园服务净利降两成,关联交易收入仅占2.9%,发力增值服务充电桩日进超10万

自2018年分拆上市以来&#xff0c;碧桂园服务经历过非常高速的发展&#xff0c;曾是物管市场的“并购王”&#xff0c;但从2023年开始&#xff0c;希望从外延式的增长向内生式增长转型&#xff0c;将往期的经验与教训&#xff0c;通过投后管理沉淀下来&#xff0c;向高质量发展…

nginx多https证书配置精简

其实有很多方式&#xff0c;网上看到一个这个方法&#xff0c;给大家介绍一下。 首先&#xff0c;开启支持-TLS SNI support Nginx开启单IP多SSL证书支持-TLS SNI support Nginx支持单IP多域名SSL证书需要OpenSSL支持&#xff0c;首先需要编译安装一个高版本的openssl。 检查…

04 Python进阶:MySQL-PyMySQL

什么是 PyMySQL&#xff1f; PyMySQL 是一个用于 Python 的纯 Python MySQL 客户端库&#xff0c;提供了与 MySQL 数据库进行交互的功能。PyMySQL 允许 Python 开发人员连接到 MySQL 数据库服务器&#xff0c;并执行诸如查询、插入、更新和删除等数据库操作。 以下是 PyMySQL …

自动驾驶领域中的感知,决策,控制

目录 一、自动驾驶领域感知决策控制概论 二、自动驾驶感知 三、自动驾驶决策 四、自动驾驶控制 一、自动驾驶领域感知决策控制概论 1.感知&#xff08;Perception&#xff09;&#xff1a;感知是指系统通过各种传感器来感知周围环境的能力&#xff0c;包括识别和理解道路、…

第29篇:秒表计时器

Q&#xff1a;本期我们采用计数器来实现秒表计时器&#xff0c;循环进行0~9计时。 A&#xff1a;在数码管HEX0上循环从0到9计数&#xff0c;间隔时间为1s&#xff0c;使用计数器实现1s时间间隔。 DE2-115开发板提供了50MHz时钟&#xff0c;触发器直接以50MHz信号作为同步时钟…

过亿级别的用户数据如何检查用户名是否存在?

目录 引言用户名存在性检查的挑战用户规模庞大带来的性能挑战数据一致性与并发性问题防止恶意行为的挑战 常见的解决方案基于数据库的方案基于缓存的方案基于分布式系统的方案基于搜索引擎的方案 案例分析与实践经验分享社交媒体平台的用户名检查方案 引言 随着互联网的普及和数…

redis的Bitmaps详细介绍

Redis的 Bitmaps&#xff08;位图&#xff09;并不是一种特殊的数据类型&#xff0c;而是字符串的二进制操作。虽然在 Redis 内部&#xff0c;BitMaps 是以字符串数据类型来存储的&#xff0c;但是它们却可以使用一些特殊的命令进行操作。如下是关于Redis Bitmaps的详细介绍&am…

PS从入门到精通视频各类教程整理全集,包含素材、作业等(9)复发

PS从入门到精通视频各类教程整理全集&#xff0c;包含素材、作业等 最新PS以及插件合集&#xff0c;可在我以往文章中找到 由于阿里云盘有分享次受限制和文件大小限制&#xff0c;今天先分享到这里&#xff0c;后续持续更新 第一课 ——第三课素材文件 https://www.alipan.c…

怎么在UE过场动画中加入振动效果

我们已经学会了怎么在游戏中加入振动效果&#xff0c;比较典型的交互场景如&#xff1a;在开枪时让手柄同步振动&#xff0c;实现起来真的很简单&#xff0c;就是定义场景和事件&#xff0c;然后在游戏事件发生时播放特定的振动资源文件&#xff0c;跟播放音效是极其相似的&…

探索Linux的挂载操作

在Linux这个强大的操作系统中&#xff0c;挂载操作是一个基本而重要的概念。它涉及到文件系统、设备和数据访问&#xff0c;对于理解Linux的工作方式至关重要。那么&#xff0c;挂载操作究竟是什么&#xff0c;为什么我们需要它&#xff0c;如果没有它&#xff0c;我们将面临什…

2024年华为OD机试真题-找数字-Java-OD统一考试(C卷)

题目描述: 小扇和小船今天又玩起来了数字游戏,小船给小扇一个正整数n (1<=n<=1e9),小扇需要找到一个比n大的数字m,使得m和n对应的二进制中1的个数要相同(如4对应二进制100,8对应二进制1000,1的个数都为1),现在求m的最小值。 输入描述: 输入:第一行输入一个正整数…

【实时监控主机与某个IP的网络连接情况】

Python脚本 写个脚本监控主机与某几个IP的连接情况&#xff0c;发现存在这种连接的&#xff0c;记录连接起始时间、源IP源、端口、目的IP、目的端口等信息 import os import time import subprocess from typing import List# 目标IP列表 TARGET_IPS ["192.168.1.1&quo…

基因组de novo组装

分以下几个部分&#xff1a; CLR组装 HIFI组装 ONT组装 二、三代数据矫正 组装结果评估 一、CLR组装 下机数据&#xff1a; 主要用那个bam文件 软件&#xff1a;wtdbg2 第一步&#xff1a;bam转fasta文件 参考&#xff1a;https://www.jianshu.com/p/03c7eb11102d # 进行基…

基于单片机放大电路程控放大特性参数设计

**单片机设计介绍&#xff0c;基于单片机放大电路程控放大特性参数设计 文章目录 一 概要二、功能设计三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机放大电路程控放大特性参数设计是一个结合了单片机编程和放大电路技术的综合性项目。以下是对该设计项目的概…