【leetcode】——第 400 场周赛,2题选手签个到

第一题:100307. 候诊室中的最少椅子数

给你一个字符串 s,模拟每秒钟的事件 i

  • 如果 s[i] == 'E',表示有一位顾客进入候诊室并占用一把椅子。
  • 如果 s[i] == 'L',表示有一位顾客离开候诊室,从而释放一把椅子。

返回保证每位进入候诊室的顾客都能有椅子坐的 最少 椅子数,假设候诊室最初是 空的 

 

示例 1:

输入:s = "EEEEEEE"

输出:7

解释:

每秒后都有一个顾客进入候诊室,没有人离开。因此,至少需要 7 把椅子。

示例 2:

输入:s = "ELELEEL"

输出:2

解释:

假设候诊室里有 2 把椅子。下表显示了每秒钟等候室的状态。

事件候诊室的人数可用的椅子数
0Enter11
1Leave02
2Enter11
3Leave02
4Enter11
5Enter20
6Leave11

示例 3:

输入:s = "ELEELEELLL"

输出:3

解释:

假设候诊室里有 3 把椅子。下表显示了每秒钟等候室的状态。

事件候诊室的人数可用的椅子数
0Enter12
1Leave03
2Enter12
3Enter21
4Leave12
5Enter21
6Enter30
7Leave21
8Leave12
9Leave03

 

提示:

  • 1 <= s.length <= 50
  • s 仅由字母 'E' 和 'L' 组成。
  • s 表示一个有效的进出序列。

题解

class Solution:
    def minimumChairs(self, s: str) -> int:
        q = float("-inf")
        w = 0
        for i in range(len(s)):
            if s[i] == "E":
                w += 1
            else:
                w -= 1
            q = max(w,q)
        return q

#思路:就是在便利的同时维护最大值即可。

第二题:100311. 无需开会的工作日

给你一个正整数 days,表示员工可工作的总天数(从第 1 天开始)。另给你一个二维数组 meetings,长度为 n,其中 meetings[i] = [start_i, end_i] 表示第 i 次会议的开始和结束天数(包含首尾)。

返回员工可工作且没有安排会议的天数。

注意:会议时间可能会有重叠。

 

示例 1:

输入:days = 10, meetings = [[5,7],[1,3],[9,10]]

输出:2

解释:

第 4 天和第 8 天没有安排会议。

示例 2:

输入:days = 5, meetings = [[2,4],[1,3]]

输出:1

解释:

第 5 天没有安排会议。

示例 3:

输入:days = 6, meetings = [[1,6]]

输出:0

解释:

所有工作日都安排了会议。

 

提示:

  • 1 <= days <= 10**9
  • 1 <= meetings.length <= 10**5
  • meetings[i].length == 2
  • 1 <= meetings[i][0] <= meetings[i][1] <= days

 题解

class Solution:
    def countDays(self, days: int, meetings: List[List[int]]) -> int:
        meetings.sort(key = lambda x:(x[0],x[1]))
        w = 0
        stack = [meetings[0]]
        for i in range(1,len(meetings)):
            if meetings[i][0] <= stack[-1][1] and meetings[i][1] >= stack[-1][1]:
                stack.append([stack[-1][0],meetings[i][1]])
                stack.pop(-2)
            elif meetings[i][1] >= stack[-1][1]:
                stack.append(meetings[i])
        print(stack)
        for i,j in stack:
            w += abs(j - i) + 1
        return days - w
#由示例2可以看出存在相交区间,所以我们要对区间进行修改,修改的方法:先按左临界值大小排序,再按右临界值大小排序,再遍历每个数组如果数组的第一个值小于等于前一个数组的右临界值,那么就改变这两个数组且右临界值取这两个数组的最大值,如果不在就入栈
#做一个栈可以用来修改数组,因为每个可能要修改的数组总是在栈顶的,所以可以用栈这个后进先出的数据结构。
#最后我们遍历这个栈也就是修改好了的数组,算出总和最后让days来减就好了。

 

 

  • 18
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值