华为OD机考题分享

第一题:

    有个N个正整数组成的序列,给定整数sum, 
    求长度最长的连续子序列,使他们的和等于sum 
    返回子序列长度,如果没有满足要求的序列,返回-1

这道题想到了leetcode78的那道组合的位扩展写法,

第二题:

    乱序数组,删除所有重复元素 使得每个元素只出现一次,
    并且按照出现的次数的由高到低进行排序 
    相同出现次数,按照第一次出现的顺序进行先后排序(要求稳定) 

这道题写得比较恶心,挺暴力了,用了三个哈希字典,分别映射:数字——出现次数,出现次数——[数字列表],数字——第一次出现的位置

第三题:

    有N个网络结点,和M条路径,给一个时延表,表的每个元素为[源节点,目的结点,路径长度]
    然后提供一个要求的源节点,和目的结点,求出源节点到目的结点的最短路径

这个题用的Dijkstra算法,之前没做过这种题,好在考试时间比较富裕,现场凭着考研时稀薄的记忆推了一下,没AC,有些边界问题没考虑到,但是也通过大部分了。
#笔试题目##华为#
全部评论
第二题 感觉可以构建一个对象:元素,出现位置,出现次数,使用map存储 :key 元素 ,value 对象 ,首先进行依次遍历,构建map,然后将Collections.sort方法重写Comparator比较方法,首先按照出现 次数倒序,然后按照出现位置升序
2
送花
回复
分享
发布于 2022-03-27 16:21
你的od机考怎么比其他人难很多
1
送花
回复
分享
发布于 2022-03-28 05:12
秋招专场
校招火热招聘中
官网直投
楼主请问考试的时候每道题可以提交多次还是只能提交一次?
点赞
送花
回复
分享
发布于 2022-04-07 15:48
华为南京、东莞、北京研究所OD岗位招聘,小伙伴们可以看过来~抓紧私信我姓名联系方式 【招聘要求】 1、统招全日制本科及以上学历,计算机、电子、通信等相关专业 2、工作地点:南京、东莞、北京 3、掌握Java、Python、C/C++、JS等主流开发语言中的一种 【内推优势】 1)已经成功内推多人,入职率很高哦! 2)通过我内推投递岗位,简历可获得优先筛选,可以帮助查询内推进度,有需要可以给到你一些面试建议哈! 注意,是社招岗位,应届生也可以面试,但是要毕业后才能发offer,抓紧私信我姓名联系方式
点赞
送花
回复
分享
发布于 2022-04-24 17:44
第二题用python7行就搞定了,java比较麻烦
点赞
送花
回复
分享
发布于 2022-04-27 14:47
第一题,只会暴力的dfs求全部,第二题也是和楼主差不多。不过评论区,说用set的想法不错,就是时间复杂度是否会超呢? 第三题 直接放弃了!
点赞
送花
回复
分享
发布于 2022-04-27 22:37
第二题花五分钟写了一下,如果机试都这么简单就好了
点赞
送花
回复
分享
发布于 2022-04-30 21:16

相关推荐

11 67 评论
分享
牛客网
牛客企业服务