Given a positive integer n, return the number of all possible attendance records with length n, which will be regarded as rewardable. The answer may be very large, return it after mod 109 + 7.

A student attendance record is a string that only contains the following three characters:

  1. 'A' : Absent.
  2. 'L' : Late.
  3. 'P' : Present.

A record is regarded as rewardable if it doesn't contain more than one 'A' (absent) or more than two continuous 'L' (late).

Example 1:

Input: n = 2
Output: 8
Explanation:
There are 8 records with length 2 will be regarded as rewardable:
"PP" , "AP", "PA", "LP", "PL", "AL", "LA", "LL"
Only "AA" won't be regarded as rewardable owing to more than one absent times.

Note: The value of n won't exceed 100,000.

Approach #1: DP. [C++]

class Solution {
public:
int checkRecord(int n) {
int m = 1000000007;
int *A = new int [n+5];
int *P = new int [n+5];
int *L = new int [n+5]; P[0] = 1;
L[0] = 1;
L[1] = 3;
A[0] = 1;
A[1] = 2;
A[2] = 4; if(n == 1) return 3; for(int i = 1; i < n; i++)
{
A[i - 1] %= m;
P[i - 1] %= m;
L[i - 1] %= m; P[i] = ((A[i - 1] + P[i - 1]) % m + L[i - 1]) % m; if(i > 1) L[i] = ((A[i - 1] + P[i - 1]) % m + (A[i - 2] + P[i - 2]) % m) % m; if(i > 2) A[i] = ((A[i - 1] + A[i - 2]) % m + A[i - 3]) % m;
} return ((A[n - 1] % m + P[n - 1] % m) % m + L[n - 1] % m) % m;
}
};

At the first time i initial A, P, L arrays with n, the compiler hint that AddressSanitizer: heap-buffer-overflow on address. After i modified n to n+5, it compiled successfully.

Analysis:

1. Thinking process

1.1 Divide the whole problem into sub-problems:

Before introducing the way to calculate the number of all possible attendance records with length n, we divide the problem into 3 part.

As the attendance records is made by 3 characters('P', 'L', 'A'), the total number can be divided into

Total = ended with P + ended with L + ended with A.

If we define following series

T(n) is the total number of all possible attendance records with length n.

P(n) is the total number of all possible attendance records with length n.

L(n) is the total number of all possible attendance records with length n.

A(n) is the total number of all possible attendance records with length n.

It can be inferred that

T(n) = A(n) + P(n) + L(n), n >= 1

1.2 Solve the sub-problems by dynamic programming

As I use dynamic programming, I need to find out the recurive relaion in 3 sub-problems.

2.2.1 Calculate P(n)

It can be inferred that

If we add a 'P' to an attendance records with length n-1, we will get an attendance records ended with 'P' with length n.

For an attendance record with length n-1.

  • If its (n-1)th character is 'P' ---- CAN add 'P'. ('PP')
  • If its (n-1)th character is 'A' ---- CAN add 'P'. ('AP')
  • If its (n-1)th character is 'L' ---- CAN add 'P'. ('LP')

which means:

P(n) = A(n-1) + P(n-1) + L(n-1), n >= 2.

and we have initial value for the recursive relation

A(1) = P(1) = L(1) = 1.

1.2.2 Calculate L(n)

Similary,

If we add a 'L' to an attendance records with length n-1, we will get an attendance records ended with 'L' with length n.

But the resulting attendance records must be regarded as rewardable!

As the rule is that a record is regarded as rewardable if it doesn't contain.

more than two continuous 'L' (late).

We need to consider the situations when we can add 'L' to an attendance record with length n-1 and it's still regarded as rewardable.

For an attendance record with length n-1.

  • If its (n-1)th character is 'P' ---- CAN add 'L'. ('PL')
  • If its (n-1)th character is 'A' ---- CAN add 'L'. ('AL')

  • If its (n-1)th character is 'L':

    • If its (n-2)th character is 'A' ---- CAN add 'L'. ('ALL')
    • If its (n-2)th character is 'P' ---- CAN add 'L'. ('PLL')
    • If its (n-2)th character is 'L' ---- CAN NOT add 'L'. ('LLL' breaks the rule).

which means:

L(n) = A(n-1) + P(n-1) + A(n-2) + P(n-2), n>= 3.

and we have initial value for the recursive relation

A(1) = P(1) = 1

A(2) = 2, P(2) = 3

and

L(1) = 1, L(2) = 3

1.2.3 Calculate A(n).

Similary,

If we add a 'A' to an attendance records with length n-1, we will get an attendance records endeds with 'A' with length n.

But resulting attendance records must be regarded as rewardable!

As the rule is that a record is regarded as rewardable if it doesn't contain

more than one 'A' (absent)

We need to consider the situations when we can add 'A' to an attedance record with length n-1 and it's still regarded as rewardable.

For an attendance record with length n-1.

  • If its (n-1)th character is 'A' ---- CAN NOT add 'A'. ("AA" break the rule)
  • If its (n-1)th character is 'P' and has no 'A' ---- CAN add 'A'.
  • If its (n-1)th character is 'L' and has no 'A' ---- CAN add 'A'.

If we define series

noAP(n) is the total number of all possible attendance records ended with 'P' with length n and with no 'A'.

noAL(n) is the total number of all possible attendance records ended with 'L' with length n and with no 'A'.

It can be inferred that

A(n) = noAP(n-1) + noAL(n-1), n>= 2.

and we have initial value for the recursive relation

A(1) = 1

noAP(1) = noAL(1) = 1

1.2.4 Calculate noAP(n) and noAL(n)

In 2.2.3, 2 new series noAP(n) and noAL(n) is introduced. Now we focus on the recursive relation in noAP(n) and noAL(n).

For noAP(n), we need to consider the situation when we can add 'P' to an attendance record with length n-1 and no 'A' and it's still regarded as rewardable.

Since noAP(n) has no 'A', we don't need to consider the situation when its (n-1)th character is 'A'.

For an attendance record with length n-1, we can get only 2 situations

  • If its (n-1)th character is 'P' and has no 'A' ---- CAN add 'P'.
  • If its (n-1)th character is 'L' and has no 'A' ---- CAN add 'P'.

which means

noAP(n) = noAP(n-1) + noAP(n-1), n>= 2.

and we have initial value for the recursive relation

noAP(1) = noAL(1) = 1.

For noAL(n), we need to consider the situations when we can add 'L' to an attendance record with length n-1 and no 'A' ans it's still regraded as rewardable.

Since noAL(n) has no 'A', we don'r need to consider the situation when its (n-1)th character is 'A'.

For an attendance record with length n-1, we can get

  • If its (n-1)th character is 'P' and has no 'A' ---- CAN add 'L'. ("PL")
  • If its (n-1)th character is ‘L' and has no 'A'.
    • If its (n-2)th character is 'P' and has no 'A' ---- CAN add 'L'.
    • If its (n-2)th character is 'L' and has no 'A' ---- CAN NOT  add 'L'.

which mean

noAL(n) = noAP(n-1) + noAP(n-2), n>= 3.

and we have initial value for the recursive relation

noAP(1) = noAL(1) = 1.

and

noAL(2) = 2

1.3 Recursive relationship summarizaion.

The answer to the whole problem is T(n), and

T(n) = A(n) + P(n) + L(n), n >= 1.

Recursive formula:

P(n) = A(n - 1) + P(n - 1) + L(n - 1), n ≥ 2.

A(n) = noAP(n - 1) + noAL(n - 1), n ≥ 2.

noAP(n) = noAP(n - 1) + noAL(n - 1), n ≥ 2.

L(n) = A(n - 1) + P(n - 1) + A(n - 2) + P(n - 2), n ≥ 3.

noAL(n) = noAP(n - 1) + noAP(n - 2), n ≥ 3.

with initial value

A(1) = P(1) = L(1) = 1.

noAP(1) = noAL(1) = 1.

L(2) = 3.

noAL(2) = 2.

1.4 Simplifying.

When n >= 4, the 3 formulas

A(n) = noAP(n - 1) + noAL(n - 1), n ≥ 2.

noAP(n) = noAP(n - 1) + noAL(n - 1), n ≥ 2.

noAL(n) = noAP(n - 1) + noAP(n - 2), n ≥ 3.

can be simplified to

A(n) = A(n - 1) + A(n - 2) + A(n - 3), n ≥ 4.

Finally, the recursive formula group becomes

P(n) = A(n - 1) + P(n - 1) + L(n - 1), n ≥ 2.

L(n) = A(n - 1) + P(n - 1) + A(n - 2) + P(n - 2), n ≥ 3.

A(n) = A(n - 1) + A(n - 2) + A(n - 3), n ≥ 4.

Here, noAP(n) and noAL(n) disappeared.

with initial value

P(1) = 1.

L(1) = 1, L(2) = 3.

A(1) = 1, A(2) = 2, A(3) = 4.

1.5 Do modulus

The result need to be return after mod 10^9 + 7.

Since the result is generated by adding a lot of middle results together. in order to make sure that every middle result and the final result won't exceed INT_MAX, we need to do modulus for every middle result. and for every 2-middle-result-addition.

2. Complexity analysis

2.1 Time complexity

Since the algorithm is one-pass from 1 to n.

The time complexity is O(n).

2.2 Space Complexity

Since 3 array are used P(n), L(n), A(n), the total size is 3n.

The space complexity is O(n).

Reference:

https://leetcode.com/problems/student-attendance-record-ii/discuss/101643/Share-my-O(n)-C%2B%2B-DP-solution-with-thinking-process-and-explanation

552. Student Attendance Record II的更多相关文章

  1. [LeetCode] 552. Student Attendance Record II 学生出勤记录之二

    Given a positive integer n, return the number of all possible attendance records with length n, whic ...

  2. 【leetcode】552. Student Attendance Record II

    题目如下: Given a positive integer n, return the number of all possible attendance records with length n ...

  3. 552 Student Attendance Record II 学生出勤记录 II

    给定一个正整数 n,返回长度为 n 的所有可被视为可奖励的出勤记录的数量. 答案可能非常大,你只需返回结果mod 109 + 7的值.学生出勤记录是只包含以下三个字符的字符串:    1.'A' : ...

  4. [LeetCode] Student Attendance Record II 学生出勤记录之二

    Given a positive integer n, return the number of all possible attendance records with length n, whic ...

  5. [Swift]LeetCode552. 学生出勤记录 II | Student Attendance Record II

    Given a positive integer n, return the number of all possible attendance records with length n, whic ...

  6. 551. Student Attendance Record I + Student Attendance Record II

    ▶ 一个学生的考勤状况是一个字符串,其中各字符的含义是:A 缺勤,L 迟到,P 正常.如果一个学生考勤状况中 A 不超过一个,且没有连续两个 L(L 可以有多个,但是不能连续),则称该学生达标(原文表 ...

  7. 551. Student Attendance Record I 从字符串判断学生考勤

    [抄题]: You are given a string representing an attendance record for a student. The record only contai ...

  8. 551. Student Attendance Record I【easy】

    551. Student Attendance Record I[easy] You are given a string representing an attendance record for ...

  9. 【leetcode_easy】551. Student Attendance Record I

    problem 551. Student Attendance Record I 题意: solution: class Solution { public: bool checkRecord(str ...

随机推荐

  1. html5 filereader 读取图片信息

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  2. 跟我学算法-图像识别之图像分类(下)(GoogleNet网络, ResNet残差网络, ResNext网络, CNN设计准则)

    1.GoogleNet 网络: Inception V1 - Inception V2 - Inception V3 - Inception V4 1. Inception v1 split - me ...

  3. Mybatis之XML使用Enum枚举传递数据

    在Mybatis中,处理枚举类的TypeHandler有两个: EnumTypeHandler: 用于保存枚举名 EnumOrdinalTypeHandler: 用于保存枚举的序号. 在实际项目中,以 ...

  4. FP昨天的新单,今天交期回写到2020年

    昨天新单6900000053,回写交期到2020年.在此视图查看此单回写的日期V_OUT_SHIPMENT_PLAN_TESTS,可看到日期是2020年. 1.检查OUT_SHIPMENT_PLAN表 ...

  5. Linux基石【第二篇】虚拟网络三种连接方式(转载)

    在虚拟机上安装完Centos系统后,开始配置静态IP,以方便在本宿主机上可以访问虚拟机,在曲折的配置中,了解到虚拟机还有三种连接方式:Bridged,NAT和Host-only,于是,我又一轮新的各种 ...

  6. 使用javascript,jquery实现的图片轮播功能

    使用javascript,jquery实现的图片轮播功能本功能采用最基础的javascript和一些简单的jquery技术实现,易理解,以修改使用,代码简易,适合刚开始接触到网站开发的朋友们参考.可以 ...

  7. 22-python爬虫解决gbk乱码问题

    转载自: python爬虫解决gbk乱码问题   今天尝试了下爬虫,爬取一本小说,忘语的凡人修仙仙界篇,当然这样不好,大家要支持正版. 爬取过程中是老套路,先获取网页源代码 # -*- coding: ...

  8. android studio打包apk

    转载:http://chenfeicqq.iteye.com/blog/1889160 1)Android Studio菜单Build->Generate Signed APK      (2) ...

  9. Halcon选择一堆region中面积第N大的region的算法实现

    以下图为例: 比如我想把面积第2小的那个“小正方形”选择出来,算法代码如下: read_image (Yuan, 'C:/Users/happy xia/Desktop/yuan.png') bina ...

  10. python教学视频

    3 X王的 链接: http://pan.baidu.com/s/1bW2UrO 密码: quit4 django 链接: http://pan.baidu.com/s/1o8UsNDS 密码: 8x ...