- 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年互联网公司技术面试全攻略:编程与算法题解答
1.数组与字符串(5题,共30分)
1.1(6分)给定一个字符串,请反转该字符串中的每个单词,但保持单词顺序不变。例如,输入`theskyisblue`,输出`eh_tkysieulb`。
解答:
python
defreverse_words(s:str)-str:
words=s.split()
reversed_words=[word[::-1]forwordinwords]
return.join(reversed_words)
解析:
-先按空格分割字符串,得到单词列表。
-对每个单词进行反转。
-最后用空格拼接回来。
1.2(8分)给定两个字符串`s`和`t`,判断`t`是否是`s`的字母异位词(即字母相同,顺序可以不同)。例如,`s=anagram`,`t=nagaram`,返回`True`。
解答:
python
defis_anagram(s:str,t:str)-bool:
iflen(s)!=len(t):
returnFalse
count=[0]26
fora,binzip(s,t):
count[ord(a)-ord(a)]+=1
count[ord(b)-ord(a)]-=1
returnall(c==0forcincount)
解析:
-长度不等直接返回`False`。
-使用数组统计每个字母的差值,最后全为0即为异位词。
1.3(7分)给定一个包含字母和数字的字符串,找出其中最长的回文子串。例如,输入`babad`,输出`bab`或`aba`。
解答:
python
deflongest_palindrome(s:str)-str:
ifnots:
return
start,end=0,0
foriinrange(len(s)):
len1=expand_from_center(s,i,i)
len2=expand_from_center(s,i,i+1)
max_len=max(len1,len2)
ifmax_lenend-start:
start=i-(max_len-1)//2
end=i+max_len//2
returns[start:end+1]
defexpand_from_center(s:str,left:int,right:int)-int:
whileleft=0andrightlen(s)ands[left]==s[right]:
left-=1
right+=1
returnright-left-1
解析:
-遍历每个字符,以它为中心向两边扩展,分别考虑奇数和偶数长度的回文。
-记录最大回文子串的起始和结束位置。
1.4(6分)给定一个包含重复字符的字符串,返回其中不重复的字符组成的字符串。例如,输入`aabbcc`,输出`abc`。
解答:
python
defunique_chars(s:str)-str:
return.join([charforcharinsifs.count(char)==1])
解析:
-遍历字符串,用`count`方法统计每个字符的出现次数,只保留出现一次的字符。
1.5(5分)给定一个字符串,统计其中每个字符的出现次数。例如,输入`hello`,输出`{h:1,e:1,l:2,o:1}`。
解答:
python
defcount_chars(s:str)-dict:
count={}
forcharins:
count[char]=count.get(char,0)+1
returncount
解析:
-使用字典记录每个字符的出现次数,`get`方法可以简化计数逻辑。
2.链表(5题,共35分)
2.1(7分)给定一个链表,删除其中的重复元素,返回不重复的链表。例如,输入`1-1-2-3-3`,输出`1-2-3`。
解答:
python
classListNode:
def__init__(self,val=0,next=None):
self.val=val
self.next=next
defdelete_duplicates(head:ListNode)-ListNode:
du
您可能关注的文档
最近下载
- 2026年中考语文一轮复习:18篇名著阅读 练习题汇编(含答案).pdf VIP
- 成都中医药大学细胞生物学期末考试题.pdf VIP
- (一诊)成都市2023级高三高中毕业班第一次诊断性检测语文试卷(含官方答案).docx
- 甲型流感(甲流)护理查房课件.pptx VIP
- 政治丨八省联考2026届高三上学期12月第一次T8联考试卷及答案.pdf VIP
- GB∕T38836-2020农村三格式户厕建设技术规范..pdf
- 2025时事政治必考试题库及完整答案详解(全国通用).docx VIP
- 人教版八年级物理上册 专题01 机械运动【考题猜想】(86题17大类型).docx VIP
- 一、工程训练简介课件.ppt VIP
- 专题6.5用一次函数解决问题(5种方法7类题型)(知识点梳理与题型分类讲解)-2024-2025学年八年级数学上册基础知识专项突破讲与练(苏科版)[含答案].pdf VIP
原创力文档


文档评论(0)