一、55. 跳跃游戏(最新解答)
给你一个非负整数数组 nums ,你最初位于数组的 第一个下标 。数组中的每个元素代表你在该位置可以跳跃的最大长度。
判断你是否能够到达最后一个下标,如果可以,返回 true ;否则,返回 false
示例 1:
输入:nums = [2,3,1,1,4]
输出:true
解释:可以先跳 1 步,从下标 0 到达下标 1, 然后再从下标 1 跳 3 步到达最后一个下标。
示例 2:
输入:nums = [3,2,1,0,4]
输出:false
解释:无论怎样,总会到达下标为 3 的位置。但该下标的最大跳跃长度是 0 , 所以永远不可能到达最后一个下标。
贪心思路:
跳跃本质:每次跳跃更新本次能跳跃的最远距离,但是要注意边界问题
max_num<i,如果当前跳跃的最远距离,比每次跳1步都小,说明前面有0,不然不会每次只跳1步都少
每次跳完要更新能达到的最远距离 max_num=max(max_num,i+nums[i])
class S55:
def func(self, nums):
max_num = 0
for i in range(len(nums)):
if max_num<i:
return False
max_num=max(max_num,i+nums[i])
return True
res=S55()
# nums=[2,3,1,1,4]
nums=[3,2,1,0,4]
print(res.func(nums))
二、274. H 指数
提示
中等
425
相关企业
给你一个整数数组 citations ,其中 citations[i] 表示研究者的第 i 篇论文被引用的次数。计算并返回该研究者的 h 指数。
根据维基百科上 h 指数的定义:h 代表“高引用次数” ,一名科研人员的 h 指数 是指他(她)至少发表了 h 篇论文,并且每篇论文 至少 被引用 h 次。如果 h 有多种可能的值,h 指数 是其中最大的那个。
示例 1:
输入:citations = [3,0,6,1,5]
输出:3
解释:给定数组表示研究者总共有 5 篇论文,每篇论文相应的被引用了 3, 0, 6, 1, 5 次。
由于研究者有 3 篇论文每篇 至少 被引用了 3 次,其余两篇论文每篇被引用 不多于 3 次,所以她的 h 指数是 3。
示例 2:
输入:citations = [1,3,1]
输出:1
class Solution(object):
def hIndex(self, citations):
citations.sort(reverse=True)
for i, v in enumerate(citations):
if v <= i:
return i
res = Solution()
citations = [1, 3, 1]
print(res.hIndex(citations))
三、125. 验证回文串
简单
712
相关企业
如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
字母和数字都属于字母数字字符。
给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 。
示例 1:
输入: s = “A man, a plan, a canal: Panama”
输出:true
解释:“amanaplanacanalpanama” 是回文串。
示例 2:
输入:s = “race a car”
输出:false
解释:“raceacar” 不是回文串。
示例 3:
输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 “” 。
由于空字符串正着反着读都一样,所以是回文串。
def test5(s):
s=s.lower()
left = 0
right = len(s) - 1
while left < right:
while not s[left].isalpha():
left+=1
while not s[right].isalpha():
right-=1
if s[left]!=s[right]:
return False
else:
left+=1
right-=1
return True
s = " "
print(test5(s))