【2023秋招】2023华为od4.28三道题

news2024/11/27 2:18:48

2023大厂笔试模拟练习网站(含题解)

www.codefun2000.com
最近我们一直在将收集到的各种大厂笔试的解题思路还原成题目并制作数据,挂载到我们的OJ上,供大家学习交流,体会笔试难度。现已录入200+道互联网大厂模拟练习题,还在极速更新中。欢迎关注公众号“塔子哥学算法”获取最新消息。
在这里插入图片描述

今天带来的是4.28华为od春招的三道题目。最近有很多热爱刷题的小伙伴主动地将自己的做题过程与思路录制成视频分享在B站,欢迎大家前去学习支持!视频链接:https://space.bilibili.com/298539770

每道题目附有思路提示,对应的题解(各种语言)欢迎前往www.codefun2000.com查看。

第一题

题目内容

输入单行英文句子,里面包含英文字母,空格以及 ,.? 三种标点符号,请将句子内每个单词进行倒序,并输出倒序后的语句。

输入描述

输入为一个字符串 S S S 。( 1 ≤ S . l e n g t h ( ) ≤ 100 1\le S.length()\le 100 1S.length()100

注意:

标点符号左右的空格 ≥ \ge 0,单词间空格 > \gt > 0

输出描述

输出逆序后的字符串

样例

样例一

输入

yM eman si boB.

输出

My name is Bob.

样例二

输入

woh era uoy ?I ma enif.

输出

how are you ?I am fine.
思路: 双指针

第二题

题目内容

日志采集是运维系统的的核心组件。日志是按行生成,每行记做一条,由采集系统分批上报。

如果上报太频繁,会对服务端造成压力;如果上报太晚,会降低用户的体验;如果次上报的条数太多,会导致超时失败为此,项目组设计了如下的上报策略:

  1. 每成功上报一条日志,奖励1分
  2. 每条日志每延迟上报1秒,扣1分
  3. 积累日志达到100条,必须立即上报

给出日志序列,根据该规则,计算首次上报能获得的最多积分数。

输入描述

输入为按时序产生的日志条数 T 1 , T 2 , . . . , T n T_1,T_2,...,T_n T1,T2,...,Tn 。( 1 ≤ n ≤ 1000 , 0 ≤ T i ≤ 100 1\le n\le 1000,0\le T_i\le 100 1n1000,0Ti100

输出描述

输出为一个整数,表示首次上报最多能获得的积分数。

样例

样例一

输入

1 98 1

输出

98

样例说明

采集系统第 2 2 2 个时刻上报,可获得最大积分 ( 98 + 1 ) − 1 = 98 (98+1)-1=98 (98+1)1=98

样例二

输入

50 60 1

输出

50

样例解释

如果第 1 1 1 个时刻上报,获得积分 50 50 50 。如果第 2 2 2 个时刻上报,最多上报 100 100 100 条,前 50 50 50 条延迟上报 1 1 1 s,每条扣除 1 1 1 分,共获得积分为 100 − 50 = 50 100-50=50 10050=50

思路:模拟/dp

第三题

题目内容

对于任意两个正整数 A A A B B B ,定义它们之间的差异值和相似值:

差异值: A A A B B B 转换成二进制后,对于二进制的每一位,对应位置的bit值不相同则为1,否则为0;

相似值: A A A B B B 转换成二进制后,对于二进制的每一位,对应位置的bit值都为1则为1,否则为0;

现在有 n n n 个正整数 A 0 A_0 A0 A ( n − 1 ) A_{(n-1)} A(n1) ,问有多少对 ( i , j ) (i,j) (i,j) ( 0 ≤ i < j < n 0\le i\lt j\lt n 0i<j<n ), A A A A j A_j Aj 的差异值大于相似值。

假设 A = 5 A=5 A=5 B = 3 B=3 B=3 ;则 A A A 的二进制表示 101 101 101 B B B 的二进制表示 011 011 011 ;则 A A A B B B 的差异值二进制为 110 110 110 ;相似值二进制为 001 001 001 A A A B B B 的差异值十进制等于 6 6 6 ,相似值十进制等于 1 1 1 ,满足条件。

输入描述

输入第一行为一个整数 n n n ,表示数组的大小。

输入第二行为 n n n 个整数,第 i i i 个元素为 a i a_i ai

1 ≤ n ≤ 1 0 5 1\le n \le 10^5 1n105 1 ≤ a i ≤ 2 30 1\le a_i \le 2^{30} 1ai230

输出描述

输出为一个整数,表示满足差异值大于相似值的对数。

样例

样例一

输入

4
4 3 5 2

输出

4

样例解释

满足条件的分别是 ( 0 , 1 ) ( 0 , 3 ) ( 1 , 2 ) ( 2 , 3 ) (0,1)(0,3)(1,2)(2,3) (0,1)(0,3)(1,2)(2,3) ,共 4 4 4 对。

样例二

输入

5
3 5 2 8 4

输出

8

样例解释

满足条件的分别是 ( 0 , 1 ) ( 0 , 3 ) ( 0 , 4 ) ( 1 , 2 ) ( 1 , 3 ) ( 2 , 3 ) ( 2 , ) ( 3 , 4 ) (0,1)(0,3)(0,4)(1,2)(1,3)(2,3)(2,)(3,4) (0,1)(0,3)(0,4)(1,2)(1,3)(2,3)(2,)(3,4) ,共 8 8 8 对。

思路:01字典树

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

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

相关文章

测试开发工程师到底是做什么的?你真的知道吗

目录 一二三线互联网公司对测试开发工程师的要求&#xff1a; 测试开发工程师的具体职责&#xff1a; 不要迷失方向 总结&#xff1a; 测试开发工程师必看视频教程&#xff1a; 一二三线互联网公司对测试开发工程师的要求&#xff1a; 现在很多测试的同事对测试开发工程师…

实现第一个服务器版本的表白墙程序

文章目录 表白墙前言1. 环境部署1.1 创建maven项目1.2 引入依赖1.3 创建目录结构1.4 部署程序 2. 前端页面3. 后端实现3.1 后端逻辑3.2 后端代码 表白墙 前言 基于MySQL数据库和servlet实现的前后端交互的服务器版本表白墙。在页面输入表白内容&#xff0c;在本地通过数据库存…

大数据Doris(二十三):Rollup物化索引作用和注意点

文章目录 Rollup物化索引作用和注意点 一、Rollup物化索引作用 1、改变索引 2、聚合数据

操作系统王道考研学习(二)操作系统的特征

目录 操作系统的特征&#xff1a;并发、共享、虚拟、异步 操作系统中并发为什么那么重要&#xff1f; 讲一讲多道程序技术 介绍一下空分复用技术 异步下程序是走走停停的 操作系统的特征&#xff1a;并发、共享、虚拟、异步 并发和共享 虚拟和异步 &#xff08;为什么要并…

物联网的体系架构

物联网中常见的计算模式&#xff1a;云计算、边缘计算、雾计算等 云计算&#xff1a;一种利用互联网实现随时随地、按需、便捷地使用共享计算设施、存储设备、应用程序等资源的计算模式。边缘计算&#xff1a;在靠近物或数据源头的网络边缘侧&#xff0c;融合网络、计算、存储…

本周前半周总结

刷题刷了六道 青训营视频补看 软件杯项目素材收集&#xff0c;首页制作ing 前面这六道题的题解&#xff1a; 题目1&#xff1a; 这是个交互题&#xff0c;目前遇到的交互题都是用二分解决的。 本题使用二分精准定位拥有重量为2的石头的堆。 为避免时间超限&#xff0c;应该再…

k8s1.20版本部署RabbitMQ集群(持久化)——2023.05

文章目录 一、集群概况二、RabbitMQ集群部署2.1 安装NFS2.2 创建storageclass存储类2.3 部署RabbitMQ集群2.4 测试 一、集群概况 主机规划 节点IPk8s-master1192.168.2.245k8s-master2192.168.2.246k8s-master3192.168.2.247k8s-node1192.168.2.248NFS、Rancher192.168.2.251…

阿里巴巴 菜鸟Java面经

目录 1.ArrayList和LinkedList的区别2.两个各自装啥数据合适3.final和finally的区别4.catch里面有个return&#xff0c;finally执行不执行5.线程的创建方式6.ThreadLocal7.序列化8.抽象类和接口的区别9.数据库的四大特性10.事务的一致性是啥11.事务的隔离级别12.可重复读是个啥…

inspect.exe安装使用

官网下载 https://developer.microsoft.com/zh-cn/windows/downloads/windows-sdk/ 官网教程 https://learn.microsoft.com/zh-cn/windows/win32/winauto/inspect-objects 要求 系统要求 Windows SDK 具有以下最低系统要求&#xff1a; 支持的操作系统 Windows 10版本 150…

chatgpt赋能Python-pycharm如何跳过教程

PyCharm如何跳过教程&#xff1a;快速掌握Python编程 如果你是一个有10年python编程经验的工程师&#xff0c;那么你肯定不需要再从头开始学习python&#xff0c;更不需要花费大量时间来学习PyCharm的教程。你需要的是一个快速而高效地使用PyCharm的方法&#xff0c;以便能够更…

chatgpt赋能Python-pandas预处理

介绍 Pandas是一个强大的Python库&#xff0c;专门用于数据操作和分析。在数据处理和分析的过程中&#xff0c;Pandas是一个不可或缺的工具。它提供了简单而灵活的数据结构&#xff0c;如Series和DataFrame&#xff0c;这些数据结构可以帮助我们快速预处理数据。 本文将介绍P…

虚拟机 01 jdk环境的安装与配置

01.第一步&#xff1a;进入到工作目录中&#xff0c;然后将目录中所有的资源都删掉 &#xff0c;此处的工作目录/usr/local/src 使用的命令是rm -rf * 02.第二步&#xff1a;将windows系统的jdk8的安装文件上传到Linux中 直接在window界面中选中压缩文件拖到Linux命令行中 完…

区间预测 | MATLAB实现QGPR高斯过程分位数回归时间序列区间预测

区间预测 | MATLAB实现QGPR高斯过程分位数回归时间序列区间预测 目录 区间预测 | MATLAB实现QGPR高斯过程分位数回归时间序列区间预测效果一览基本介绍模型描述程序设计参考资料 效果一览 基本介绍 MATLAB实现QGPR高斯过程分位数回归时间序列区间预测 1.基于高斯过程回归&#…

chatgpt赋能Python-pycharm怎么粘贴代码

PyCharm&#xff1a;如何在编辑器中粘贴代码 作为一个有多年 Python 编程经验的工程师&#xff0c;我可以说 PyCharm 是 Python 编辑器中的佼佼者&#xff0c;它凭借其智能化、强大的功能和用户友好的界面而受到广泛赞誉。在该编程软件中&#xff0c;如果你需要粘贴代码&#…

【我的C++入门之旅】(上)

前言 C的发展史 1979年&#xff0c;贝尔实验室的Bjarne等人试图分析unix内核的时候&#xff0c;试图将内核模块化&#xff0c;但是发现C语言有很多的不足之处&#xff0c;于是在C语言的基础上进行扩展&#xff0c;增加了类的机制&#xff0c;完成了一个可以运行的预处理程序&…

chatgpt赋能Python-pycharm备份

PyCharm备份——数据安全之道 在软件开发过程中&#xff0c;数据备份是一项至关重要的任务。特别是对于PyCharm这样的IDE来说&#xff0c;开发者在其中执行大量的代码编写、调试、测试、运行等操作&#xff0c;需要在相对固定的时间点 backup 数据&#xff0c;以防止数据丢失带…

【AFNetWorking源码一】

文章目录 前言一.原生的网络请求发送方式1.1 原生GET1.2 原生PSOT 二.AFN2.1 AFN的基本架构分析2.2 以GET为例分析AFN使用流程&#xff08;AFHTTPSessionManager2.2.1 AFN如何生生成对应的sessionManager2.2.2. AFURLSessionManager的初始化2.2.3 task的三种代理2.2.3.1 setDel…

力扣sql中等篇练习(二十二)

力扣sql中等篇练习(二十二) 1 坚定的友谊 1.1 题目内容 1.1.1 基本题目信息 1.1.2 示例输入输出 1.2 示例sql语句 # Write your MySQL query statement below # ①求出所有朋友关系的总表 WITH T as (SELECT user1_id ,user2_idFROM friendshipUNION SELECT user2_id user1…

前端学习--Vue(1)webpack

前端工程化 模块化&#xff08;js、css模块化、资源模块化&#xff09; 组件化&#xff08;复用现有的UI结构、样式、行为&#xff09; 规范化&#xff08;目录结构划分、编码规范化、接口文档规范化、git分支管理&#xff09; 自动化&#xff08;自动化构建、自动部署、自动化…

试用阿里云云拨测对Web网站的网页性能进行测试并分析

目录 前言 云拨测操作步骤 1.开通应用实时监控服务ARMS 2.成功登录后&#xff0c;在产品类别下选择中间件>应用实时监控服务&#xff0c;在云拨测卡片上单击立即试用。 3.登录ARMS控制台&#xff0c;在左侧导航栏中选择云拨测>定时拨测&#xff0c;在定时拨测页面右上…