- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
第PAGE页共NUMPAGES页
2026年工程师晋升之钥:专业面试问题解答
一、编程与算法(5题,每题10分,共50分)
1.题目:
请编写一个函数,实现快速排序算法。输入一个无序数组,输出排序后的数组。要求说明时间复杂度和空间复杂度,并举例说明如何处理包含重复元素的数组。
答案:
python
defquick_sort(arr):
iflen(arr)=1:
returnarr
pivot=arr[len(arr)//2]
left=[xforxinarrifxpivot]
middle=[xforxinarrifx==pivot]
right=[xforxinarrifxpivot]
returnquick_sort(left)+middle+quick_sort(right)
时间复杂度:O(nlogn),最坏情况O(n2);空间复杂度:O(logn)
示例:处理重复元素
arr=[4,2,2,8,3,3,1]
print(quick_sort(arr))#输出:[1,2,2,3,3,4,8]
解析:
快速排序通过分治思想实现,选择基准值(pivot)将数组分为三部分:小于、等于、大于基准值的子数组。递归排序左右子数组,合并后得到有序数组。时间复杂度取决于分区均衡性,空间复杂度主要来自递归栈。
2.题目:
给定一个包含重复数字的数组,请编写代码找出所有不重复的组合,组合长度为3。例如,输入`[1,2,2,3]`,输出`[[1,2,3],[1,2,2]]`。
答案:
python
fromitertoolsimportcombinations
deffind_unique_combinations(arr):
unique=set(arr)
return[list(comb)forcombincombinations(unique,3)]
示例
arr=[1,2,2,3]
print(find_unique_combinations(arr))#输出:[[1,2,3],[1,2,2]]
解析:
利用`binations`生成所有长度为3的组合,然后通过集合去重。注意组合顺序不重要,因此去重后能有效避免重复组合。
3.题目:
请编写一个函数,实现二分查找算法。输入有序数组和一个目标值,返回目标值的索引。若不存在则返回`-1`。要求处理数组中存在重复元素的情况。
答案:
python
defbinary_search(arr,target):
left,right=0,len(arr)-1
whileleft=right:
mid=(left+right)//2
ifarr[mid]==target:
returnmid
elifarr[mid]target:
left=mid+1
else:
right=mid-1
return-1
示例
arr=[1,2,4,4,4,7,9]
print(binary_search(arr,4))#输出:2(第一个4的索引)
解析:
二分查找适用于有序数组,通过不断缩小查找范围来定位目标值。存在重复元素时,若需要返回第一个或最后一个索引,需在找到目标值后继续向左或向右搜索。
4.题目:
请编写代码实现一个简单的LRU(最近最少使用)缓存,支持`get`和`put`操作。缓存容量为3,超出时淘汰最久未使用的元素。
答案:
python
classLRUCache:
def__init__(self,capacity:int):
self.cache={}
self.capacity=capacity
self.order=[]
defget(self,key:int)-int:
ifkeyinself.cache:
self.order.remove(key)
self.order.append(key)
returnself.cache[key]
return-1
defput(self,key:int,value:int)-None:
ifkeyinself.cache:
self.order.remove(key)
eliflen(self.cache)==self.capacity:
oldest=self.order.pop(0)
delself.cache[oldest]
self.ca
您可能关注的文档
- 2026年华为公司办公室主任面试全攻略及答案解析.docx
- 2026年安全部安全专员面试题及答案.docx
- 2026年医药行业合规风控专员的面试题集.docx
- 2026年国际关系主任面试题及答案解析.docx
- 2026年专业车评编辑专业知识题测试样卷.docx
- 2026年IT企业招聘经理面试指南与答案.docx
- 2026年个人护理产品研发岗位面试题.docx
- 2026年考试题电子集团项目管理的核心知识点.docx
- 2026年项目经理助理的考试题及答案.docx
- 2026年专业知识更新能力面试题.docx
- 选修nbsp电磁振荡市公开课金奖市赛课教案.docx
- 《小学生卫生习惯养成》健康教育教学设计.docx
- 年高考英语新课标1卷D篇说题课件-高考英语一轮复习(1).pptx
- 小学语文三年级上册《六个矮儿子》教学设计.docx
- 匹配口语交际意见不同怎么办教案.docx
- Unit6PlanforYourselfSectionA(2a-2d)课件人教版英语八年级上册.pptx
- Unit3Conservation单元典型句式结构讲解及对应练习课件北师大版高中英语选择性().pptx
- 专题4哲学与文化(原卷版).docx
- 百年辉煌百年未有之大变局图文教案.docx
- 等差数列的前n项和课件-高二上学期数学人教A版选择性.pptx
原创力文档


文档评论(0)