leetcode每日一题——美团笔试题【3】
第一题
:
股票的最大利润
假设把某股票的价格按照时间先后顺序存储在数组中,请问买卖该股票一次可能获得的最大利润是多少?示例 1:输入: [7,1,5,3,6,4]
输出: 5
解释: 在第 2 天(股票价格 = 1)的时候买入,在第 5 天(股票价格 = 6)的时候卖出,最大利润 = 6-1 = 5 。注意利润不能是 7-1 = 6, 因为卖出价格需要大于买入价格。
示例 2:输入: [7,6,4,3,1]
输出: 0
解释: 在这种情况下, 没有交易完成, 所以最大利润为 0。限制:0 <= 数组长度 <= 10^5
解法
:
- 先判断边界情况,只有一个价格或者列表为空的时候,无法收益,返回0;
- 然后先指定序列中第一个为最小值,然后从他后面依次循环每个值,如果遇到更小的则更新为当前值,如果遇到比他大的则用当前值减去最小值与之前的结果对比,取两者中的最大值。
代码
:
class Solution:def maxProfit(self, prices: List[int]) -> int:if len(prices) == 0 or len(prices) == 1:return 0res = 0buy = prices[0]for i in range(1,len(prices) - 1):if prices[i] <= buy:buy = prices[i]else:res = max(res,prices[i] - buy) return res
第二题
:
有效的括号
给定一个只包括 '(',')','{','}','[',']' 的字符串 s ,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。
每个右括号都有一个对应的相同类型的左括号。示例 1:输入:s = "()"
输出:true
示例 2:输入:s = "()[]{}"
输出:true
示例 3:输入:s = "(]"
输出:false提示:1 <= s.length <= 104
s 仅由括号 '()[]{}' 组成
解法
:
第一种解法:
可采用字符串的replace方法,将s中的() {} []
均替换为空字符串,最后替换完成如果s == ‘’ 则证明字符串为有效的括号
代码
:
class Solution:def isValid(self, s: str) -> bool:while '{}' in s or '[]' in s or '()' in s:s = s.replace('{}','')s = s.replace('[]','')s = s.replace('()','')return s == ''
第二种解法:
- 将三种左右括号分别作为key和value存储到字典中;
- 创建一个列表作为
存储右括号的栈
; - 循环字符串s,若当前循环到的字符属于字典中的key,则将其对应的value追加到第二步创建的栈中;
- 若当前循环到的字符不属于字典中的key(
也就意味着当前的字符为右括号
),判断栈是否非空的情况且栈顶元素是否能够匹配当前字符的情况:
- 当栈为空时,则not stack为True,也就说明循环到当前的字符都没有出现左括号,不然栈一定不为空,那么不满足条件,则返回False,说明s不是有效的括号;
- 当栈不为空时,里面存的肯定是右括号,那么直接拿栈顶元素与当前字符进行对比,如果相等则弹栈,不等则返回False;
- 将整个字符串中的字符循环完毕,返回栈是否为空的布尔值。
代码
:
class Solution:def isValid(self, s: str) -> bool:mapping_dict = {'(':')','[':']','{':'}'}stack = []for char in s:if char in mapping_dict.keys():stack.append(mapping_dict[char])else:# 栈为空则not stack为True反之则为False,# char != stack[-1]则表示当前右括号字符和栈顶元素匹配不上if not stack or char != stack[-1]:return Falsestack.pop()return len(stack) == 0