auto commit

This commit is contained in:
CyC2018 2019-10-27 15:51:57 +08:00
parent 39e10a02d9
commit bb098b5250
6 changed files with 50 additions and 34 deletions

View File

@ -30,8 +30,14 @@ Output: index1=1, index2=2
- 如果 sum > target移动较大的元素使 sum 变小一些
- 如果 sum < target移动较小的元素使 sum 变大一些
数组中的元素最多遍历一次时间复杂度为 O(N)额外只使用了两个变量空间复杂度为
O(1)
<div align="center"> <img src="https://cs-notes-1256109796.cos.ap-guangzhou.myqcloud.com/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif" width="200px"> </div><br>
```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/)

View File

@ -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
## 回溯引用条件
条件判断为某个子表达式是否匹配如果匹配则需要继续匹配条件表达式后面的内容
条件为某个子表达式是否匹配如果匹配则需要继续匹配条件表达式后面的内容
**正则表达式**

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

View File

@ -30,8 +30,14 @@ Output: index1=1, index2=2
- 如果 sum > target移动较大的元素使 sum 变小一些
- 如果 sum < target移动较小的元素使 sum 变大一些
数组中的元素最多遍历一次时间复杂度为 O(N)额外只使用了两个变量空间复杂度为
O(1)
<div align="center"> <img src="pics/437cb54c-5970-4ba9-b2ef-2541f7d6c81e.gif" width="200px"> </div><br>
```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/)

Binary file not shown.

After

Width:  |  Height:  |  Size: 11 KiB

View File

@ -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
## 回溯引用条件
条件判断为某个子表达式是否匹配如果匹配则需要继续匹配条件表达式后面的内容
条件为某个子表达式是否匹配如果匹配则需要继续匹配条件表达式后面的内容
**正则表达式**