力扣刷题--3168. 候诊室中的最少椅子数【简单】

题目描述

给你一个字符串 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 表示一个有效的进出序列。

算法分析

类比上公交车,用ans表示此时车上的人数,每次上一个人ans ++,每次下一个人,ans就--,然后维护最大值count,返回count

完整代码

cpp 复制代码
class Solution {  
public:  
    int minimumChairs(string s) {  
        //维护最大的count即可,类比上公交车  
        int count=0;//最大值  
        int ans=0;  
        for(auto i:s)  
        {
            if(i=='E')  
                ans++;  
            else  
                ans--;  
            count=max(ans,count);  
        }
        return count;  
    }
};

本篇完!

相关推荐
wefg13 分钟前
【算法】动态规划
算法·动态规划
机器学习之心12 分钟前
198种组合算法+优化TCN-Transformer+SHAP分析+新数据预测+多输出!深度学习可解释分析,强烈安利,粉丝必备!
深度学习·算法·transformer·shap分析·新数据预测
狐5713 分钟前
2026-01-12-LeetCode刷题笔记-1266-访问所有点的最小时间.md
笔记·算法·leetcode
Gorgous—l14 分钟前
数据结构算法学习:LeetCode热题100-栈篇(有效的括号、最小栈、字符串解码、每日温度、柱状图中最大的矩形)
数据结构·学习·算法
小郭团队15 分钟前
教育公平的探索
大数据·人工智能·嵌入式硬件·算法·硬件架构
瑞雨溪19 分钟前
力扣题解:740.删除并获得点数
算法·leetcode·职场和发展
LeeeX!21 分钟前
基于YOLO11实现明厨亮灶系统实时检测【多场景数据+模型训练、推理、导出】
深度学习·算法·目标检测·数据集·明厨亮灶
红队it23 分钟前
【Spark+Hadoop】基于spark+hadoop游戏评论数据分析可视化大屏(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)✅
大数据·hadoop·分布式·算法·游戏·数据分析·spark
程序员-King.23 分钟前
day125—二分查找—寻找峰值(LeetCode-162)
算法·leetcode·职场和发展
qianbo_insist24 分钟前
基于APAP算法的图像和视频拼接
算法·数学建模·图像拼接