- 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.题目:
给定一个包含重复元素的数组,请找出数组中所有不重复的三元组,使得三元组的和等于给定的目标值。要求时间复杂度为O(n2)。
示例:
输入:nums=[-1,0,1,2,-1,-4],target=0
输出:[[-1,-1,2],[-1,0,1]]
答案:
cpp
includevector
includealgorithm
usingnamespacestd;
classSolution{
public:
vectorvectorintthreeSum(vectorintnums,inttarget){
vectorvectorintresult;
if(nums.size()3)returnresult;
sort(nums.begin(),nums.end());
for(inti=0;inums.size()-2;++i){
//跳过重复的元素
if(i0nums[i]==nums[i-1])continue;
intleft=i+1,right=nums.size()-1;
while(leftright){
intsum=nums[i]+nums[left]+nums[right];
if(sum==target){
result.push_back({nums[i],nums[left],nums[right]});
//跳过重复的元素
while(leftrightnums[left]==nums[left+1])left++;
while(leftrightnums[right]==nums[right-1])right--;
left++;
right--;
}
elseif(sumtarget){
left++;
}
else{
right--;
}
}
}
returnresult;
}
};
解析:
首先对数组进行排序,然后使用固定指针法。对于每个数字`nums[i]`,使用双指针`left`和`right`分别指向`i+1`和数组末尾。如果三数之和等于目标值,则记录该三元组,并移动双指针跳过重复元素;如果和小于目标值,则左指针右移;如果和大于目标值,则右指针左移。时间复杂度为O(n2),空间复杂度为O(1)(不计结果存储空间)。
2.题目:
实现一个LRU(LeastRecentlyUsed)缓存,支持get和put操作。缓存容量为固定值。
示例:
LRUCachecache=newLRUCache(2);
cache.put(1,1);
cache.put(2,2);
cache.get(1);//返回1
cache.put(3,3);//去除键2
cache.get(2);//返回-1(未找到)
cache.put(4,4);//去除键1
答案:
cpp
includeunordered_map
includelist
classLRUCache{
private:
intcapacity;
std::listintkeys;
std::unordered_mapint,intcache;
public:
LRUCache(intcapacity_):capacity(capacity_){}
intget(intkey){
autoit=cache.find(key);
if(it==cache.end())return-1;
//将key移到链表头部(最近使用)
keys.remove(key);
keys.push_front(key);
returnit-second;
}
voidput(intkey,intvalue){
autoit=cache.find(key);
if(it!=cache.end()){
//更新值并移动到头部
it-second=value;
keys.remove(key);
keys.push_front(key);
}
else{
//如果超出容量,删除最久未使用的key
if(cache.size()==capacity){
intoldest_key=keys.back();
keys.pop_back();
cache.erase(oldest_key);
}
您可能关注的文档
- 2026年设备维护专员技能考试题库含答案.docx
- 2026年金蝶云服务运维工程师面试题及答案.docx
- 2026年银行柜员招聘面试问题集及解析.docx
- 2026年投资银行面试题及答案专业与心态并重.docx
- 2026年外汇知识培训与考核题集.docx
- 2026年内容营销策划师面试题及答案.docx
- 2026年基于容器的Web应用自动化测试.docx
- 2026年运营部员工培训与考核制度.docx
- 2026年客服经理投诉处理面试题及答案.docx
- 2026年通信工程师面试题及操作技巧.docx
- 基于数字化工具的自我评价与同伴互评评价体系设计教学研究课题报告.docx
- 高中生对音乐推荐中AI算法个性化偏见的认知研究课题报告教学研究课题报告.docx
- 2025年宁波市公务员录用考试《行测》真题.docx
- 基于人工智能的区域教育均衡发展策略与政策支持体系构建教学研究课题报告.docx
- 高中历史教学中历史纪录片教学资源开发与应用课题报告教学研究课题报告.docx
- 四川省泸州市古蔺中学2025-2026学年高一上学期12月阶段性考试生物试题(解析版).docx
- 2025年宁波市公务员录用考试《行政职业能力测试》真题.docx
- 2025年宁波市公务员公安考试真题.docx
- 教师数字能力培养与教学评价改革研究教学研究课题报告.docx
- 高中生物教学中生物技术前沿知识融入教学实践课题报告教学研究课题报告.docx
最近下载
- 九年级上册科学浙教版物质的分类教案.doc VIP
- 2022年福建技术师范学院计算机科学与技术专业《计算机组成原理》科目期末试卷A(有答案).docx VIP
- 企业职工基本养老保险退休时间申请书.docx VIP
- 2025至2030中国鼻胃管和口胃管行业产业运行态势及投资规划深度研究报告.docx VIP
- 短视频文案创新撰写方法.pptx
- 充电模块CEG75050 说明书用户手册.pdf
- jstz3902a jstz3905b jstz3907智能摆闸安装调试说明书中文版a1.pdf VIP
- 2025年黑龙江省生态环境厅下属事业单位考试真题.pdf VIP
- 2023年福建技术师范学院计算机科学与技术专业《计算机组成原理》科目期末试卷B(有答案).docx VIP
- 2023年福建技术师范学院计算机科学与技术专业《计算机组成原理》科目期末试卷A(有答案).docx VIP
原创力文档


文档评论(0)