【算法】算法题-20231128

一、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_i,表示当前能够跳跃到的最远位置,
然后遍历数组,对于每一个位置,我们都检查一下从当前位置能否跳跃到更远的位置,
如果能够跳跃到更远的位置,那么我们就更新 max_i。

class Solution:
    def canJump(self, nums):
        max_i = 0
        for i, jump in enumerate(nums):
            if max_i >= i and i + jump > max_i:
                max_i = i + jump
        return max_i >= i


res = Solution()
nums = [3, 2, 1, 0, 4]
print(res.canJump(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
        return i + 1


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))

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/YZL40514131/article/details/134658599