From 2c6cb71a5f855aef6bbb97aeab967189ce62ce5b Mon Sep 17 00:00:00 2001 From: Libin YANG Date: Tue, 7 Jan 2025 19:48:20 +0800 Subject: [PATCH] feat: add solutions to lc problems (#3935) --- .../README.md | 2 +- .../README_EN.md | 6 +++++- solution/2200-2299/2297.Jump Game VIII/README.md | 4 ++-- solution/2200-2299/2297.Jump Game VIII/README_EN.md | 8 +++++++- .../2299.Strong Password Checker II/README.md | 4 ++-- .../2299.Strong Password Checker II/README_EN.md | 10 +++++++++- .../2310.Sum of Numbers With Units Digit K/README.md | 6 ++++-- .../README_EN.md | 10 +++++++++- 8 files changed, 39 insertions(+), 11 deletions(-) diff --git a/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README.md b/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README.md index 7496714fe4dcd..ae693f886a701 100644 --- a/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README.md +++ b/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README.md @@ -55,7 +55,7 @@ tags: ### 方法一:哈希表 -我们初始化答案为 $+\infty$,遍历数组,对于每个数字 $x$,如果 $last[x]$ 存在,则表示 $x$ 有一对匹配卡牌,此时更新答案为 $ans = min(ans, i - last[x] + 1)$,最后如果答案为 $+\infty$,则返回 $-1$,否则返回答案。 +我们初始化答案为 $+\infty$,遍历数组,对于每个数字 $x$,如果 $\textit{last}[x]$ 存在,则表示 $x$ 有一对匹配卡牌,此时更新答案为 $\textit{ans} = \min(\textit{ans}, i - \textit{last}[x] + 1)$,最后如果答案为 $+\infty$,则返回 $-1$,否则返回答案。 时间复杂度 $O(n)$,空间复杂度 $O(n)$。其中 $n$ 为数组长度。 diff --git a/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README_EN.md b/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README_EN.md index cc859ce215c35..a08bae6f58dd4 100644 --- a/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README_EN.md +++ b/solution/2200-2299/2260.Minimum Consecutive Cards to Pick Up/README_EN.md @@ -55,7 +55,11 @@ tags: -### Solution 1 +### Solution 1: Hash Table + +We initialize the answer as $+\infty$. We traverse the array, and for each number $x$, if $\textit{last}[x]$ exists, it means $x$ has a matching pair of cards. In this case, we update the answer to $\textit{ans} = \min(\textit{ans}, i - \textit{last}[x] + 1)$. Finally, if the answer is $+\infty$, we return $-1$; otherwise, we return the answer. + +The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the length of the array. diff --git a/solution/2200-2299/2297.Jump Game VIII/README.md b/solution/2200-2299/2297.Jump Game VIII/README.md index 222ec0fb652ce..e94fd97ae19fa 100644 --- a/solution/2200-2299/2297.Jump Game VIII/README.md +++ b/solution/2200-2299/2297.Jump Game VIII/README.md @@ -74,9 +74,9 @@ tags: ### 方法一:单调栈 + 动态规划 -根据题目描述,我们实际上需要找到 $nums[i]$ 的下一个大于等于 $nums[i]$ 的位置 $j$,以及下一个小于 $nums[i]$ 的位置 $j$。我们利用单调栈可以在 $O(n)$ 的时间内找到这两个位置,然后构建邻接表 $g$,其中 $g[i]$ 表示下标 $i$ 可以跳转到的下标。 +根据题目描述,我们实际上需要找到 $\textit{nums}[i]$ 的下一个大于等于 $\textit{nums}[i]$ 的位置 $j$,以及下一个小于 $\textit{nums}[i]$ 的位置 $j$。我们利用单调栈可以在 $O(n)$ 的时间内找到这两个位置,然后构建邻接表 $g$,其中 $g[i]$ 表示下标 $i$ 可以跳转到的下标。 -然后我们使用动态规划求解最小代价。设 $f[i]$ 表示跳转到下标 $i$ 的最小代价,初始时 $f[0] = 0$,其余 $f[i] = \infty$。我们从小到大枚举下标 $i$,对于每个 $i$,我们枚举 $g[i]$ 中的每个下标 $j$,进行状态转移 $f[j] = \min(f[j], f[i] + costs[j])$。答案为 $f[n - 1]$。 +然后我们使用动态规划求解最小代价。设 $f[i]$ 表示跳转到下标 $i$ 的最小代价,初始时 $f[0] = 0$,其余 $f[i] = \infty$。我们从小到大枚举下标 $i$,对于每个 $i$,我们枚举 $g[i]$ 中的每个下标 $j$,进行状态转移 $f[j] = \min(f[j], f[i] + \textit{costs}[j])$。答案为 $f[n - 1]$。 时间复杂度 $O(n)$,空间复杂度 $O(n)$。其中 $n$ 为数组长度。 diff --git a/solution/2200-2299/2297.Jump Game VIII/README_EN.md b/solution/2200-2299/2297.Jump Game VIII/README_EN.md index 876bea63d4678..45cf68ae5a1d9 100644 --- a/solution/2200-2299/2297.Jump Game VIII/README_EN.md +++ b/solution/2200-2299/2297.Jump Game VIII/README_EN.md @@ -72,7 +72,13 @@ The total cost is 2. Note that you cannot jump directly from index 0 to index 2 -### Solution 1 +### Solution 1: Monotonic Stack + Dynamic Programming + +According to the problem description, we need to find the next position $j$ where $\textit{nums}[j]$ is greater than or equal to $\textit{nums}[i]$, and the next position $j$ where $\textit{nums}[j]$ is less than $\textit{nums}[i]$. We can use a monotonic stack to find these two positions in $O(n)$ time, and then construct an adjacency list $g$, where $g[i]$ represents the indices that index $i$ can jump to. + +Then we use dynamic programming to find the minimum cost. Let $f[i]$ represent the minimum cost to jump to index $i$. Initially, $f[0] = 0$ and the rest $f[i] = \infty$. We enumerate the indices $i$ from small to large. For each $i$, we enumerate each index $j$ in $g[i]$ and perform the state transition $f[j] = \min(f[j], f[i] + \textit{costs}[j])$. The answer is $f[n - 1]$. + +The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the length of the array. diff --git a/solution/2200-2299/2299.Strong Password Checker II/README.md b/solution/2200-2299/2299.Strong Password Checker II/README.md index 8df124cb5d4f2..828027648d177 100644 --- a/solution/2200-2299/2299.Strong Password Checker II/README.md +++ b/solution/2200-2299/2299.Strong Password Checker II/README.md @@ -72,9 +72,9 @@ tags: 根据题目描述,我们可以模拟检查密码是否满足题目要求的过程。 -首先,我们检查密码的长度是否小于 $8$,如果是,则返回 `false`。 +首先,我们检查密码的长度是否小于 $8$,如果是,则返回 $\textit{false}$。 -接下来,我们用一个掩码 `mask` 来记录密码是否包含小写字母、大写字母、数字和特殊字符。我们遍历密码,每次遍历到一个字符,先判断它是否和前一个字符相同,如果是,则返回 `false`。然后,根据字符的类型更新掩码 `mask`。最后,我们检查掩码 `mask` 是否为 $15$,如果是,则返回 `true`,否则返回 `false`。 +接下来,我们用一个掩码 $\textit{mask}$ 来记录密码是否包含小写字母、大写字母、数字和特殊字符。我们遍历密码,每次遍历到一个字符,先判断它是否和前一个字符相同,如果是,则返回 $\textit{false}$。然后,根据字符的类型更新掩码 $\textit{mask}$。最后,我们检查掩码 $\textit{mask}$ 是否为 $15$,如果是,则返回 $\textit{true}$,否则返回 $\textit{false}$。 时间复杂度 $O(n)$,空间复杂度 $O(1)$。其中 $n$ 为密码的长度。 diff --git a/solution/2200-2299/2299.Strong Password Checker II/README_EN.md b/solution/2200-2299/2299.Strong Password Checker II/README_EN.md index b88f2f25efe5b..954a585fafe2e 100644 --- a/solution/2200-2299/2299.Strong Password Checker II/README_EN.md +++ b/solution/2200-2299/2299.Strong Password Checker II/README_EN.md @@ -69,7 +69,15 @@ tags: -### Solution 1 +### Solution 1: Simulation + Bit Manipulation + +According to the problem description, we can simulate the process of checking whether the password meets the requirements. + +First, we check if the length of the password is less than $8$. If it is, we return $\textit{false}$. + +Next, we use a mask $\textit{mask}$ to record whether the password contains lowercase letters, uppercase letters, digits, and special characters. We traverse the password, and for each character, we first check if it is the same as the previous character. If it is, we return $\textit{false}$. Then, we update the mask $\textit{mask}$ based on the character type. Finally, we check if the mask $\textit{mask}$ is $15$. If it is, we return $\textit{true}$; otherwise, we return $\textit{false}$. + +The time complexity is $O(n)$, and the space complexity is $O(1)$. Here, $n$ is the length of the password. diff --git a/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README.md b/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README.md index de7df0a926a90..422a6846cc3c0 100644 --- a/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README.md +++ b/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README.md @@ -82,12 +82,14 @@ tags: ### 方法一:数学 + 枚举 -符合拆分条件的每个数都可以表示成 $10x_i+k$,若总共有 $n$ 个数,那么 $num-n*k$ 必然是 $10$ 的倍数。 +符合拆分条件的每个数都可以表示成 $10x_i+k$,若总共有 $n$ 个数,那么 $\textit{num}-n \times k$ 必然是 $10$ 的倍数。 -我们从小到达枚举 $n$,找到第一个满足 $num-n*k$ 是 $10$ 的倍数的 $n$。由于 $n$ 不会超过 $num$,因此 $n$ 最大枚举至 $num$。 +我们从小到达枚举 $n$,找到第一个满足 $\textit{num}-n \times k$ 是 $10$ 的倍数的 $n$。由于 $n$ 不会超过 $\textit{num}$,因此 $n$ 最大枚举至 $\textit{num}$。 也可以只考虑个位,个位满足,高位随意。 +时间复杂度 $O(n)$,其中 $n$ 为 $\textit{num}$ 的大小。空间复杂度 $O(1)$。 + #### Python3 diff --git a/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README_EN.md b/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README_EN.md index 7c19e6cc30f97..80ec93c252aa2 100644 --- a/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README_EN.md +++ b/solution/2300-2399/2310.Sum of Numbers With Units Digit K/README_EN.md @@ -79,7 +79,15 @@ It can be shown that 2 is the minimum possible size of a valid set. -### Solution 1 +### Solution 1: Math + Enumeration + +Each number that meets the splitting condition can be represented as $10x_i + k$. If there are $n$ such numbers, then $\textit{num} - n \times k$ must be a multiple of $10$. + +We enumerate $n$ from small to large, and find the first $n$ that satisfies $\textit{num} - n \times k$ being a multiple of $10$. Since $n$ cannot exceed $\textit{num}$, the maximum value of $n$ is $\textit{num}$. + +We can also only consider the units digit. If the units digit satisfies the condition, the higher digits can be arbitrary. + +The time complexity is $O(n)$, where $n$ is the size of $\textit{num}$. The space complexity is $O(1)$.