第一题:100307. 候诊室中的最少椅子数
给你一个字符串 s
,模拟每秒钟的事件 i
:
- 如果
s[i] == 'E'
,表示有一位顾客进入候诊室并占用一把椅子。 - 如果
s[i] == 'L'
,表示有一位顾客离开候诊室,从而释放一把椅子。
返回保证每位进入候诊室的顾客都能有椅子坐的 最少 椅子数,假设候诊室最初是 空的 。
示例 1:
输入:s = "EEEEEEE"
输出:7
解释:
每秒后都有一个顾客进入候诊室,没有人离开。因此,至少需要 7 把椅子。
示例 2:
输入:s = "ELELEEL"
输出:2
解释:
假设候诊室里有 2 把椅子。下表显示了每秒钟等候室的状态。
秒 | 事件 | 候诊室的人数 | 可用的椅子数 |
---|---|---|---|
0 | Enter | 1 | 1 |
1 | Leave | 0 | 2 |
2 | Enter | 1 | 1 |
3 | Leave | 0 | 2 |
4 | Enter | 1 | 1 |
5 | Enter | 2 | 0 |
6 | Leave | 1 | 1 |
示例 3:
输入:s = "ELEELEELLL"
输出:3
解释:
假设候诊室里有 3 把椅子。下表显示了每秒钟等候室的状态。
秒 | 事件 | 候诊室的人数 | 可用的椅子数 |
---|---|---|---|
0 | Enter | 1 | 2 |
1 | Leave | 0 | 3 |
2 | Enter | 1 | 2 |
3 | Enter | 2 | 1 |
4 | Leave | 1 | 2 |
5 | Enter | 2 | 1 |
6 | Enter | 3 | 0 |
7 | Leave | 2 | 1 |
8 | Leave | 1 | 2 |
9 | Leave | 0 | 3 |
提示:
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来减就好了。
标签:周赛,候诊室,示例,meetings,days,leetcode,签个,数组,stack From: https://blog.csdn.net/2301_80269840/article/details/139390090