本文最后更新于 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),即常量级别的空间复杂度。