auto commit

This commit is contained in:
CyC2018 2018-09-24 23:37:56 +08:00
parent 3a604c23e8
commit 02a61d3611
3 changed files with 10 additions and 8 deletions

View File

@ -100,7 +100,7 @@ List list = Arrays.asList(arr);
也可以使用以下方式调用 asList() 也可以使用以下方式调用 asList()
```java ```java
List list = Arrays.asList(1,2,3); List list = Arrays.asList(1, 2, 3);
``` ```
# 三、源码分析 # 三、源码分析
@ -575,7 +575,7 @@ int hash = hash(key);
int i = indexFor(hash, table.length); int i = indexFor(hash, table.length);
``` ```
(一)计算 hash 值 **4.1 计算 hash 值**
```java ```java
final int hash(Object k) { final int hash(Object k) {
@ -600,7 +600,7 @@ public final int hashCode() {
} }
``` ```
(二)取模 **4.2 取模**
令 x = 1<<4 x 2 4 次方它具有以下性质 令 x = 1<<4 x 2 4 次方它具有以下性质
@ -727,7 +727,7 @@ new capacity : 00100000
对于一个 Key 对于一个 Key
- 它的哈希值如果在第 5 位上为 0那么取模得到的结果和之前一样 - 它的哈希值如果在第 6 位上为 0那么取模得到的结果和之前一样
- 如果为 1那么得到的结果为原来的结果 +16。 - 如果为 1那么得到的结果为原来的结果 +16。
### 7. 扩容-计算数组容量 ### 7. 扩容-计算数组容量

View File

@ -2781,7 +2781,7 @@ return ret;
定义一个 tails 数组,其中 tails[i] 存储长度为 i + 1 的最长递增子序列的最后一个元素。对于一个元素 x 定义一个 tails 数组,其中 tails[i] 存储长度为 i + 1 的最长递增子序列的最后一个元素。对于一个元素 x
- 如果它大于 tails 数组所有的值,那么把它添加到 tails 后面,表示最长递增子序列长度加 1 - 如果它大于 tails 数组所有的值,那么把它添加到 tails 后面,表示最长递增子序列长度加 1
- 如果 tails[i-1] < x <= tails[i]那么更新 tails[i-1] = x - 如果 tails[i-1] < x <= tails[i]那么更新 tails[i] = x
例如对于数组 [4,3,6,5],有: 例如对于数组 [4,3,6,5],有:

View File

@ -223,14 +223,14 @@ Output:
在字符串尾部填充任意字符,使得字符串的长度等于替换之后的长度。因为一个空格要替换成三个字符(%20因此当遍历到一个空格时需要在尾部填充两个任意字符。 在字符串尾部填充任意字符,使得字符串的长度等于替换之后的长度。因为一个空格要替换成三个字符(%20因此当遍历到一个空格时需要在尾部填充两个任意字符。
令 P1 指向字符串原来的末尾位置P2 指向字符串现在的末尾位置。P1 和 P2从后向前遍历当 P1 遍历到一个空格时,就需要令 P2 指向的位置依次填充 02%(注意是逆序的),否则就填充上 P1 指向字符的值。 令 P1 指向字符串原来的末尾位置P2 指向字符串现在的末尾位置。P1 和 P2 从后向前遍历,当 P1 遍历到一个空格时,就需要令 P2 指向的位置依次填充 02%(注意是逆序的),否则就填充上 P1 指向字符的值。
从后向前遍是为了在改变 P2 所指向的内容时,不会影响到 P1 遍历原来字符串的内容。 从后向前遍是为了在改变 P2 所指向的内容时,不会影响到 P1 遍历原来字符串的内容。
```java ```java
public String replaceSpace(StringBuffer str) { public String replaceSpace(StringBuffer str) {
int P1 = str.length() - 1; int P1 = str.length() - 1;
for (int i = 0; i < P1 + 1; i++) for (int i = 0; i <= P1; i++)
if (str.charAt(i) == ' ') if (str.charAt(i) == ' ')
str.append(" "); str.append(" ");
@ -385,6 +385,7 @@ private TreeNode reConstructBinaryTree(int[] pre, int preL, int preR, int inL) {
```java ```java
public class TreeLinkNode { public class TreeLinkNode {
int val; int val;
TreeLinkNode left = null; TreeLinkNode left = null;
TreeLinkNode right = null; TreeLinkNode right = null;
@ -510,6 +511,7 @@ public int Fibonacci(int n) {
```java ```java
public class Solution { public class Solution {
private int[] fib = new int[40]; private int[] fib = new int[40];
public Solution() { public Solution() {
@ -956,7 +958,7 @@ private void printNumber(char[] number) {
```java ```java
public ListNode deleteNode(ListNode head, ListNode tobeDelete) { public ListNode deleteNode(ListNode head, ListNode tobeDelete) {
if (head == null || head.next == null || tobeDelete == null) if (head == null || tobeDelete == null)
return null; return null;
if (tobeDelete.next != null) { if (tobeDelete.next != null) {
// 要删除的节点不是尾节点 // 要删除的节点不是尾节点