leetcode-No.551. 学生出勤记录 I
本文最后更新于 2024-08-18,文章内容可能已经过时。
题目
给你一个字符串 s
表示一个学生的出勤记录,其中的每个字符用来标记当天的出勤情况(缺勤、迟到、到场)。记录中只含下面三种字符:
'A'
:Absent,缺勤'L'
:Late,迟到'P'
:Present,到场
如果学生能够 同时 满足下面两个条件,则可以获得出勤奖励:
按 总出勤 计,学生缺勤(
'A'
)严格 少于两天。学生 不会 存在 连续 3 天或 连续 3 天以上的迟到(
'L'
)记录。
如果学生可以获得出勤奖励,返回 true
;否则,返回 false
。
示例 1:
输入:s = "PPALLP"
输出:true
解释:学生缺勤次数少于 2 次,且不存在 3 天或以上的连续迟到记录。
示例 2:
输入:s = "PPALLL"
输出:false
解释:学生最后三天连续迟到,所以不满足出勤奖励的条件。
提示:
1 <= s.length <= 1000
s[i]
为'A'
、'L'
或'P'
答案代码
"""
给你一个字符串 s 表示一个学生的出勤记录,其中的每个字符用来标记当天的出勤情况(缺勤、迟到、到场)。记录中只含下面三种字符:
'A':Absent,缺勤
'L':Late,迟到
'P':Present,到场
如果学生能够 同时 满足下面两个条件,则可以获得出勤奖励:
按 总出勤 计,学生缺勤('A')严格 少于两天。
学生 不会 存在 连续 3 天或 连续 3 天以上的迟到('L')记录。
如果学生可以获得出勤奖励,返回 true ;否则,返回 false 。
示例 1:
输入:s = "PPALLP"
输出:true
解释:学生缺勤次数少于 2 次,且不存在 3 天或以上的连续迟到记录。
示例 2:
输入:s = "PPALLL"
输出:false
解释:学生最后三天连续迟到,所以不满足出勤奖励的条件。
提示:
1 <= s.length <= 1000
s[i] 为 'A'、'L' 或 'P'
"""
class Solution(object):
def checkRecord(self, s):
"""
:type s: str
:rtype: bool
"""
absent = 0
late = 0
for i in range(len(s)):
if s[i] == 'A':
absent += 1
if absent >= 2:
return False
if s[i] == 'L':
late += 1
if late >= 3:
return False
else:
late = 0
return True
if __name__ == '__main__':
s = "PPALLP"
print(Solution().checkRecord(s))
s = "PPALLL"
print(Solution().checkRecord(s))
结果分析
代码功能概述
这段代码定义了一个名为 Solution
的类,其中有一个方法 checkRecord
。这个方法接收一个字符串 s
作为参数,表示一个学生的出勤记录。出勤记录中的每个字符可以是 'P
' (到场)、'A
' (缺席) 或 'L
' (迟到)。方法的目的是检查该记录是否符合以下条件:
缺席次数不多于 1 次。
迟到次数不多于连续 3 次。
如果满足以上条件,则返回 True
;否则返回 False
。
时间复杂度分析
遍历字符串: 方法中通过一个循环来遍历输入字符串 s
中的每一个字符。字符串的长度为 n,因此时间复杂度为 O(n)。
空间复杂度分析
变量存储: 在方法内部,使用了两个整型变量 absent 和 late 来分别计数缺席和连续迟到的次数。这些变量不依赖于输入字符串的大小,因此额外的空间复杂度为 O(1)。
总结
时间复杂度: O(n),其中 n 是输入字符串 s
的长度。
空间复杂度: O(1),即常量级别的空间复杂度。