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

解法

  1. 先判断边界情况,只有一个价格或者列表为空的时候,无法收益,返回0;
  2. 然后先指定序列中第一个为最小值,然后从他后面依次循环每个值,如果遇到更小的则更新为当前值,如果遇到比他大的则用当前值减去最小值与之前的结果对比,取两者中的最大值。

代码

class Solution:
    def maxProfit(self, prices: List[int]) -> int:
    	if len(prices) == 0 or len(prices) == 1:
    		return 0
    	res = 0
    	buy = 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 == ''

第二种解法:

  1. 将三种左右括号分别作为key和value存储到字典中;
  2. 创建一个列表作为存储右括号的栈
  3. 循环字符串s,若当前循环到的字符属于字典中的key,则将其对应的value追加到第二步创建的栈中;
  4. 若当前循环到的字符不属于字典中的key(也就意味着当前的字符为右括号),判断栈是否非空的情况且栈顶元素是否能够匹配当前字符的情况:
  • 当栈为空时,则not stack为True,也就说明循环到当前的字符都没有出现左括号,不然栈一定不为空,那么不满足条件,则返回False,说明s不是有效的括号;
  • 当栈不为空时,里面存的肯定是右括号,那么直接拿栈顶元素与当前字符进行对比,如果相等则弹栈,不等则返回False;
  1. 将整个字符串中的字符循环完毕,返回栈是否为空的布尔值。

代码

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 False
                stack.pop()
        return len(stack) == 0
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值