diff --git a/docs/notes/Leetcode 题解 - 双指针.md b/docs/notes/Leetcode 题解 - 双指针.md
index 4eb7213f..7e0fdc8b 100644
--- a/docs/notes/Leetcode 题解 - 双指针.md
+++ b/docs/notes/Leetcode 题解 - 双指针.md
@@ -30,8 +30,14 @@ Output: index1=1, index2=2
- 如果 sum > target,移动较大的元素,使 sum 变小一些;
- 如果 sum < target,移动较小的元素,使 sum 变大一些。
+数组中的元素最多遍历一次,时间复杂度为 O(N)。额外只使用了两个变量,空间复杂度为
+O(1)。
+
+
+
```java
public int[] twoSum(int[] numbers, int target) {
+ if (numbers == null) return null;
int i = 0, j = numbers.length - 1;
while (i < j) {
int sum = numbers[i] + numbers[j];
@@ -49,7 +55,7 @@ public int[] twoSum(int[] numbers, int target) {
# 2. 两数平方和
-633. Sum of Square Numbers (Easy)
+633\. Sum of Square Numbers (Easy)
[Leetcode](https://leetcode.com/problems/sum-of-square-numbers/description/) / [力扣](https://leetcode-cn.com/problems/sum-of-square-numbers/description/)
@@ -80,7 +86,7 @@ public boolean judgeSquareSum(int c) {
# 3. 反转字符串中的元音字符
-345. Reverse Vowels of a String (Easy)
+345\. Reverse Vowels of a String (Easy)
[Leetcode](https://leetcode.com/problems/reverse-vowels-of-a-string/description/) / [力扣](https://leetcode-cn.com/problems/reverse-vowels-of-a-string/description/)
@@ -115,7 +121,7 @@ public String reverseVowels(String s) {
# 4. 回文字符串
-680. Valid Palindrome II (Easy)
+680\. Valid Palindrome II (Easy)
[Leetcode](https://leetcode.com/problems/valid-palindrome-ii/description/) / [力扣](https://leetcode-cn.com/problems/valid-palindrome-ii/description/)
@@ -149,7 +155,7 @@ private boolean isPalindrome(String s, int i, int j) {
# 5. 归并两个有序数组
-88. Merge Sorted Array (Easy)
+88\. Merge Sorted Array (Easy)
[Leetcode](https://leetcode.com/problems/merge-sorted-array/description/) / [力扣](https://leetcode-cn.com/problems/merge-sorted-array/description/)
@@ -185,7 +191,7 @@ public void merge(int[] nums1, int m, int[] nums2, int n) {
# 6. 判断链表是否存在环
-141. Linked List Cycle (Easy)
+141\. Linked List Cycle (Easy)
[Leetcode](https://leetcode.com/problems/linked-list-cycle/description/) / [力扣](https://leetcode-cn.com/problems/linked-list-cycle/description/)
@@ -210,7 +216,7 @@ public boolean hasCycle(ListNode head) {
# 7. 最长子序列
-524. Longest Word in Dictionary through Deleting (Medium)
+524\. Longest Word in Dictionary through Deleting (Medium)
[Leetcode](https://leetcode.com/problems/longest-word-in-dictionary-through-deleting/description/) / [力扣](https://leetcode-cn.com/problems/longest-word-in-dictionary-through-deleting/description/)
diff --git a/docs/notes/正则表达式.md b/docs/notes/正则表达式.md
index 43d5dcc7..4d59ae04 100644
--- a/docs/notes/正则表达式.md
+++ b/docs/notes/正则表达式.md
@@ -27,17 +27,17 @@
**.** 是元字符,表示它有特殊的含义,而不是字符本身的含义。如果需要匹配 . ,那么要用 \ 进行转义,即在 . 前面加上 \ 。
-正则表达式一般是区分大小写的,但是也有些实现是不区分。
+正则表达式一般是区分大小写的,但也有些实现不区分。
**正则表达式**
```
-nam.
+C.C2018
```
**匹配结果**
-My **name** is Zheng.
+My name is **CyC2018** .
# 三、匹配一组字符
@@ -82,7 +82,7 @@ abc[^0-9]
\r\n\r\n 可以匹配 Windows 下的空白行,因为它匹配两个连续的行尾标签,而这正是两条记录之间的空白行;
-## 匹配特定的字符类别
+## 匹配特定的字符
### 1. 数字元字符
@@ -105,13 +105,13 @@ abc[^0-9]
| \s | 任何一个空白字符,等价于 [\f\n\r\t\v] |
| \S | 对 \s 取非 |
-\x 匹配十六进制字符,\0 匹配八进制,例如 \x0A 对应 ASCII 字符 10,等价于 \n。
+\x 匹配十六进制字符,\0 匹配八进制,例如 \xA 对应值为 10 的 ASCII 字符 ,即 \n。
# 五、重复匹配
- **\+** 匹配 1 个或者多个字符
-- **\** * 匹配 0 个或者多个
-- **?** 匹配 0 个或者 1 个
+- **\** * 匹配 0 个或者多个字符
+- **?** 匹配 0 个或者 1 个字符
**应用**
@@ -141,12 +141,12 @@ abc[^0-9]
a.+c
```
-由于 + 是贪婪型的,因此 .+ 会匹配更可能多的内容,所以会把整个 abcabcabc 文本都匹配,而不是只匹配前面的 abc 文本。用懒惰型可以实现匹配前面的。
-
**匹配结果**
**abcabcabc**
+由于 + 是贪婪型的,因此 .+ 会匹配更可能多的内容,所以会把整个 abcabcabc 文本都匹配,而不是只匹配前面的 abc 文本。用懒惰型可以实现匹配前面的。
+
# 六、位置匹配
## 单词边界
@@ -327,7 +327,9 @@ aBCd
# 九、前后查找
-前后查找规定了匹配的内容首尾应该匹配的内容,但是又不包含首尾匹配的内容。向前查找用 **?=** 来定义,它规定了尾部匹配的内容,这个匹配的内容在 ?= 之后定义。所谓向前查找,就是规定了一个匹配的内容,然后以这个内容为尾部向前面查找需要匹配的内容。向后匹配用 ?<= 定义(注: javaScript 不支持向后匹配, java 对其支持也不完善)。
+前后查找规定了匹配的内容首尾应该匹配的内容,但是又不包含首尾匹配的内容。
+
+向前查找使用 **?=** 定义,它规定了尾部匹配的内容,这个匹配的内容在 ?= 之后定义。所谓向前查找,就是规定了一个匹配的内容,然后以这个内容为尾部向前面查找需要匹配的内容。向后匹配用 ?<= 定义(注: JavaScript 不支持向后匹配,Java 对其支持也不完善)。
**应用**
@@ -349,7 +351,7 @@ aBCd
## 回溯引用条件
-条件判断为某个子表达式是否匹配,如果匹配则需要继续匹配条件表达式后面的内容。
+条件为某个子表达式是否匹配,如果匹配则需要继续匹配条件表达式后面的内容。
**正则表达式**
diff --git a/docs/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif b/docs/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif
new file mode 100644
index 00000000..7a188a57
Binary files /dev/null and b/docs/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif differ
diff --git a/notes/Leetcode 题解 - 双指针.md b/notes/Leetcode 题解 - 双指针.md
index 4eb7213f..c189d37c 100644
--- a/notes/Leetcode 题解 - 双指针.md
+++ b/notes/Leetcode 题解 - 双指针.md
@@ -30,8 +30,14 @@ Output: index1=1, index2=2
- 如果 sum > target,移动较大的元素,使 sum 变小一些;
- 如果 sum < target,移动较小的元素,使 sum 变大一些。
+数组中的元素最多遍历一次,时间复杂度为 O(N)。额外只使用了两个变量,空间复杂度为
+O(1)。
+
+
+
```java
public int[] twoSum(int[] numbers, int target) {
+ if (numbers == null) return null;
int i = 0, j = numbers.length - 1;
while (i < j) {
int sum = numbers[i] + numbers[j];
@@ -49,7 +55,7 @@ public int[] twoSum(int[] numbers, int target) {
# 2. 两数平方和
-633. Sum of Square Numbers (Easy)
+633\. Sum of Square Numbers (Easy)
[Leetcode](https://leetcode.com/problems/sum-of-square-numbers/description/) / [力扣](https://leetcode-cn.com/problems/sum-of-square-numbers/description/)
@@ -80,7 +86,7 @@ public boolean judgeSquareSum(int c) {
# 3. 反转字符串中的元音字符
-345. Reverse Vowels of a String (Easy)
+345\. Reverse Vowels of a String (Easy)
[Leetcode](https://leetcode.com/problems/reverse-vowels-of-a-string/description/) / [力扣](https://leetcode-cn.com/problems/reverse-vowels-of-a-string/description/)
@@ -115,7 +121,7 @@ public String reverseVowels(String s) {
# 4. 回文字符串
-680. Valid Palindrome II (Easy)
+680\. Valid Palindrome II (Easy)
[Leetcode](https://leetcode.com/problems/valid-palindrome-ii/description/) / [力扣](https://leetcode-cn.com/problems/valid-palindrome-ii/description/)
@@ -149,7 +155,7 @@ private boolean isPalindrome(String s, int i, int j) {
# 5. 归并两个有序数组
-88. Merge Sorted Array (Easy)
+88\. Merge Sorted Array (Easy)
[Leetcode](https://leetcode.com/problems/merge-sorted-array/description/) / [力扣](https://leetcode-cn.com/problems/merge-sorted-array/description/)
@@ -185,7 +191,7 @@ public void merge(int[] nums1, int m, int[] nums2, int n) {
# 6. 判断链表是否存在环
-141. Linked List Cycle (Easy)
+141\. Linked List Cycle (Easy)
[Leetcode](https://leetcode.com/problems/linked-list-cycle/description/) / [力扣](https://leetcode-cn.com/problems/linked-list-cycle/description/)
@@ -210,7 +216,7 @@ public boolean hasCycle(ListNode head) {
# 7. 最长子序列
-524. Longest Word in Dictionary through Deleting (Medium)
+524\. Longest Word in Dictionary through Deleting (Medium)
[Leetcode](https://leetcode.com/problems/longest-word-in-dictionary-through-deleting/description/) / [力扣](https://leetcode-cn.com/problems/longest-word-in-dictionary-through-deleting/description/)
diff --git a/notes/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif b/notes/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif
new file mode 100644
index 00000000..7a188a57
Binary files /dev/null and b/notes/pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif differ
diff --git a/notes/正则表达式.md b/notes/正则表达式.md
index 1cfdcbf8..0067b94c 100644
--- a/notes/正则表达式.md
+++ b/notes/正则表达式.md
@@ -27,17 +27,17 @@
**.** 是元字符,表示它有特殊的含义,而不是字符本身的含义。如果需要匹配 . ,那么要用 \ 进行转义,即在 . 前面加上 \ 。
-正则表达式一般是区分大小写的,但是也有些实现是不区分。
+正则表达式一般是区分大小写的,但也有些实现不区分。
**正则表达式**
```
-nam.
+C.C2018
```
**匹配结果**
-My **name** is Zheng.
+My name is **CyC2018** .
# 三、匹配一组字符
@@ -82,7 +82,7 @@ abc[^0-9]
\r\n\r\n 可以匹配 Windows 下的空白行,因为它匹配两个连续的行尾标签,而这正是两条记录之间的空白行;
-## 匹配特定的字符类别
+## 匹配特定的字符
### 1. 数字元字符
@@ -105,13 +105,13 @@ abc[^0-9]
| \s | 任何一个空白字符,等价于 [\f\n\r\t\v] |
| \S | 对 \s 取非 |
-\x 匹配十六进制字符,\0 匹配八进制,例如 \x0A 对应 ASCII 字符 10,等价于 \n。
+\x 匹配十六进制字符,\0 匹配八进制,例如 \xA 对应值为 10 的 ASCII 字符 ,即 \n。
# 五、重复匹配
- **\+** 匹配 1 个或者多个字符
-- **\** * 匹配 0 个或者多个
-- **?** 匹配 0 个或者 1 个
+- **\** * 匹配 0 个或者多个字符
+- **?** 匹配 0 个或者 1 个字符
**应用**
@@ -141,12 +141,12 @@ abc[^0-9]
a.+c
```
-由于 + 是贪婪型的,因此 .+ 会匹配更可能多的内容,所以会把整个 abcabcabc 文本都匹配,而不是只匹配前面的 abc 文本。用懒惰型可以实现匹配前面的。
-
**匹配结果**
**abcabcabc**
+由于 + 是贪婪型的,因此 .+ 会匹配更可能多的内容,所以会把整个 abcabcabc 文本都匹配,而不是只匹配前面的 abc 文本。用懒惰型可以实现匹配前面的。
+
# 六、位置匹配
## 单词边界
@@ -327,7 +327,9 @@ aBCd
# 九、前后查找
-前后查找规定了匹配的内容首尾应该匹配的内容,但是又不包含首尾匹配的内容。向前查找用 **?=** 来定义,它规定了尾部匹配的内容,这个匹配的内容在 ?= 之后定义。所谓向前查找,就是规定了一个匹配的内容,然后以这个内容为尾部向前面查找需要匹配的内容。向后匹配用 ?<= 定义(注: javaScript 不支持向后匹配, java 对其支持也不完善)。
+前后查找规定了匹配的内容首尾应该匹配的内容,但是又不包含首尾匹配的内容。
+
+向前查找使用 **?=** 定义,它规定了尾部匹配的内容,这个匹配的内容在 ?= 之后定义。所谓向前查找,就是规定了一个匹配的内容,然后以这个内容为尾部向前面查找需要匹配的内容。向后匹配用 ?<= 定义(注: JavaScript 不支持向后匹配,Java 对其支持也不完善)。
**应用**
@@ -349,7 +351,7 @@ aBCd
## 回溯引用条件
-条件判断为某个子表达式是否匹配,如果匹配则需要继续匹配条件表达式后面的内容。
+条件为某个子表达式是否匹配,如果匹配则需要继续匹配条件表达式后面的内容。
**正则表达式**