日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

lfu算法实现java_LFU五种实现方式,从简单到复杂

發布時間:2025/3/11 编程问答 81 豆豆
生活随笔 收集整理的這篇文章主要介紹了 lfu算法实现java_LFU五种实现方式,从简单到复杂 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

最近刷力扣題,對于我這種 0 基礎來說,真的是腦殼疼啊。這個月我估計都是中等和困難題,沒有簡單題了。

幸好,力扣上有各種大牛給寫題解。看著他們行云流水的代碼,真的是羨慕不已。讓我印象最深刻的就是人稱 “甜姨” 的知心姐姐,還有名叫威哥的大哥。幾乎每天他們的題解我都是必看的。

甜姨的題解,雖然姿勢很帥,但是對于我這種新手來說,感覺不是太友好,因為思路寫的太少,不是很詳細。所以,每次我看不明白的時候,都得反復看好幾遍,才能想明白她代碼中的思路。

上個周末的一道題是,讓實現一個 LFU 緩存算法。經過我幾個小時的研究(其實,應該有8個小時以上了,沒得辦法啊,菜就得多勤奮咯),終于把甜姨的思路整明白了。為了便于以后自己復習,就把整個思路記下來了,并配上圖示和大量代碼注釋,我相信對于跟我一樣的新手來說,是非常友好的。

雖然,力扣要求是用時間復雜度 O(1) 來解,但是其它方式我感覺也有必要了解,畢竟是一個由淺到深的過程,自己實現一遍總歸是好的。因此,我就把五種求解方式,從簡單到復雜,都講一遍。

LFU實現

力扣原題描述如下:

請你為 最不經常使用(LFU)緩存算法設計并實現數據結構。它應該支持以下操作:get?和?put。

get(key)?- 如果鍵存在于緩存中,則獲取鍵的值(總是正數),否則返回 -1。

put(key, value)?- 如果鍵不存在,請設置或插入值。當緩存達到其容量時,則應該在插入新項之前,使最不經常使用的項無效。在此問題中,當存在平局(即兩個或更多個鍵具有相同使用頻率)時,應該去除 最近 最少使用的鍵。

「項的使用次數」就是自插入該項以來對其調用 get 和 put 函數的次數之和。使用次數會在對應項被移除后置為 0 。

示例:

LFUCache cache = new LFUCache( 2 /* capacity (緩存容量) */ );

cache.put(1, 1);

cache.put(2, 2);

cache.get(1); // 返回 1

cache.put(3, 3); // 去除 key 2

cache.get(2); // 返回 -1 (未找到key 2)

cache.get(3); // 返回 3

cache.put(4, 4); // 去除 key 1

cache.get(1); // 返回 -1 (未找到 key 1)

cache.get(3); // 返回 3

cache.get(4); // 返回 4

來源:力扣(LeetCode)

鏈接:https://leetcode-cn.com/problems/lfu-cache

就是要求我們設計一個 LFU 算法,根據訪問次數(訪問頻次)大小來判斷應該刪除哪個元素,get和put操作都會增加訪問頻次。當訪問頻次相等時,就判斷哪個元素是最久未使用過的,把它刪除。

因此,這道題需要考慮兩個方面,一個是訪問頻次,一個是訪問時間的先后順序。

方案一:使用優先隊列

思路:

我們可以使用JDK提供的優先隊列 PriorityQueue 來實現 。 因為優先隊列內部維護了一個二叉堆,即可以保證每次 poll 元素的時候,都可以根據我們的要求,取出當前所有元素的最大值或是最小值。只需要我們的實體類實現 Comparable 接口就可以了。

因此,我們需要定義一個 Node 來保存當前元素的訪問頻次 freq,全局的自增的 index,用于比較大小。然后定義一個 Map cache ,用于存放元素的信息。

當 cache 容量不足時,根據訪問頻次 freq 的大小來刪除最小的 freq 。若相等,則刪除 index 最小的,因為index是自增的,越大說明越是最近訪問過的,越小說明越是很長時間沒訪問過的元素。

因本質是用二叉堆實現,故時間復雜度為O(logn)。

public class LFUCache4 {

public static void main(String[] args) {

LFUCache4 cache = new LFUCache4(2);

cache.put(1, 1);

cache.put(2, 2);

// 返回 1

System.out.println(cache.get(1));

cache.put(3, 3); // 去除 key 2

// 返回 -1 (未找到key 2)

System.out.println(cache.get(2));

// 返回 3

System.out.println(cache.get(3));

cache.put(4, 4); // 去除 key 1

// 返回 -1 (未找到 key 1)

System.out.println(cache.get(1));

// 返回 3

System.out.println(cache.get(3));

// 返回 4

System.out.println(cache.get(4));

}

//緩存了所有元素的node

Map cache;

//優先隊列

Queue queue;

//緩存cache 的容量

int capacity;

//當前緩存的元素個數

int size;

//全局自增

int index = 0;

//初始化

public LFUCache4(int capacity){

this.capacity = capacity;

if(capacity > 0){

queue = new PriorityQueue<>(capacity);

}

cache = new HashMap<>();

}

public int get(int key){

Node node = cache.get(key);

// node不存在,則返回 -1

if(node == null) return -1;

//每訪問一次,頻次和全局index都自增 1

node.freq++;

node.index = index++;

// 每次都重新remove,再offer是為了讓優先隊列能夠對當前Node重排序

//不然的話,比較的 freq 和 index 就是不準確的

queue.remove(node);

queue.offer(node);

return node.value;

}

public void put(int key, int value){

//容量0,則直接返回

if(capacity == 0) return;

Node node = cache.get(key);

//如果node存在,則更新它的value值

if(node != null){

node.value = value;

node.freq++;

node.index = index++;

queue.remove(node);

queue.offer(node);

}else {

//如果cache滿了,則從優先隊列中取出一個元素,這個元素一定是頻次最小,最久未訪問過的元素

if(size == capacity){

cache.remove(queue.poll().key);

//取出元素后,size減 1

size--;

}

//否則,說明可以添加元素,于是創建一個新的node,添加到優先隊列中

Node newNode = new Node(key, value, index++);

queue.offer(newNode);

cache.put(key,newNode);

//同時,size加 1

size++;

}

}

//必須實現 Comparable 接口才可用于排序

private class Node implements Comparable{

int key;

int value;

int freq = 1;

int index;

public Node(){

}

public Node(int key, int value, int index){

this.key = key;

this.value = value;

this.index = index;

}

@Override

public int compareTo(Node o) {

//優先比較頻次 freq,頻次相同再比較index

int minus = this.freq - o.freq;

return minus == 0? this.index - o.index : minus;

}

}

}

方案二:使用一條雙向鏈表

思路:

只用一條雙向鏈表,來維護頻次和時間先后順序。那么,可以這樣想。把頻次 freq 小的放前面,頻次大的放后面。如果頻次相等,就從當前節點往后遍歷,直到找到第一個頻次比它大的元素,并插入到它前面。(當然,如果遍歷到了tail,則插入到tail前面)這樣可以保證同頻次的元素,最近訪問的總是在最后邊。

因此,總的來說,最低頻次,并且最久未訪問的元素肯定就是鏈表中最前面的那一個了。這樣的話,當 cache容量滿的時候,直接把頭結點刪除掉就可以了。但是,我們這里為了方便鏈表的插入和刪除操作,用了兩個哨兵節點,來表示頭節點 head和尾結點tail。因此,刪除頭結點就相當于刪除 head.next。

PS:哨兵節點只是為了占位,實際并不存儲有效數據,只是為了鏈表插入和刪除時,不用再判斷當前節點的位置。不然的話,若當前節點占據了頭結點或尾結點的位置,還需要重新賦值頭尾節點元素,較麻煩。

為了便于理解新節點如何插入到鏈表中合適的位置,作圖如下:

代碼如下:

public class LFUCache {

public static void main(String[] args) {

LFUCache cache = new LFUCache(2);

cache.put(1, 1);

cache.put(2, 2);

// 返回 1

System.out.println(cache.get(1));

cache.put(3, 3); // 去除 key 2

// 返回 -1 (未找到key 2)

System.out.println(cache.get(2));

// 返回 3

System.out.println(cache.get(3));

cache.put(4, 4); // 去除 key 1

// 返回 -1 (未找到 key 1)

System.out.println(cache.get(1));

// 返回 3

System.out.println(cache.get(3));

// 返回 4

System.out.println(cache.get(4));

}

private Map cache;

private Node head;

private Node tail;

private int capacity;

private int size;

public LFUCache(int capacity) {

this.capacity = capacity;

this.cache = new HashMap<>();

/**

* 初始化頭結點和尾結點,并作為哨兵節點

*/

head = new Node();

tail = new Node();

head.next = tail;

tail.pre = head;

}

public int get(int key) {

Node node = cache.get(key);

if(node == null) return -1;

node.freq++;

moveToPostion(node);

return node.value;

}

public void put(int key, int value) {

if(capacity == 0) return;

Node node = cache.get(key);

if(node != null){

node.value = value;

node.freq++;

moveToPostion(node);

}else{

//如果元素滿了

if(size == capacity){

//直接移除最前面的元素,因為這個節點就是頻次最小,且最久未訪問的節點

cache.remove(head.next.key);

removeNode(head.next);

size--;

}

Node newNode = new Node(key, value);

//把新元素添加進來

addNode(newNode);

cache.put(key,newNode);

size++;

}

}

//只要當前 node 的頻次大于等于它后邊的節點,就一直向后找,

// 直到找到第一個比當前node頻次大的節點,或者tail節點,然后插入到它前面

private void moveToPostion(Node node){

Node nextNode = node.next;

//先把當前元素刪除

removeNode(node);

//遍歷到符合要求的節點

while (node.freq >= nextNode.freq && nextNode != tail){

nextNode = nextNode.next;

}

//把當前元素插入到nextNode前面

node.pre = nextNode.pre;

node.next = nextNode;

nextNode.pre.next = node;

nextNode.pre = node;

}

//添加元素(頭插法),并移動到合適的位置

private void addNode(Node node){

node.pre = head;

node.next = head.next;

head.next.pre = node;

head.next = node;

moveToPostion(node);

}

//移除元素

private void removeNode(Node node){

node.pre.next = node.next;

node.next.pre = node.pre;

}

class Node {

int key;

int value;

int freq = 1;

//當前節點的前一個節點

Node pre;

//當前節點的后一個節點

Node next;

public Node(){

}

public Node(int key ,int value){

this.key = key;

this.value = value;

}

}

}

可以看到不管是插入元素還是刪除元素時,都不需要額外的判斷,這就是設置哨兵節點的好處。

由于每次訪問元素的時候,都需要按一定的規則把元素放置到合適的位置,因此,元素需要從前往后一直遍歷。所以,時間復雜度 O(n)。

方案三:用 LinkedHashSet維護頻次鏈表

思路:

我們不再使用一條鏈表,同時維護頻次和訪問時間了。此處,換為用 map 鍵值對來維護,用頻次作為鍵,用當前頻次對應的一條具有先后訪問順序的鏈表來作為值。它的結構如下:

Map> freqMap

由于LinkedHashSet 的 iterator迭代方法是按插入順序的,因此迭代到的第一個元素肯定是當前頻次下,最久未訪問的元素。這樣的話,當緩存 cache滿的時候,直接刪除迭代到的第一個元素就可以了。

另外 freqMap,也需要在每次訪問元素的時候,重新維護關系。從當前元素的頻次對應的雙向鏈表中移除當前元素,并加入到高頻次的鏈表中。

public class LFUCache1 {

public static void main(String[] args) {

LFUCache1 cache = new LFUCache1(2);

cache.put(1, 1);

cache.put(2, 2);

// 返回 1

System.out.println(cache.get(1));

cache.put(3, 3); // 去除 key 2

// 返回 -1 (未找到key 2)

System.out.println(cache.get(2));

// 返回 3

System.out.println(cache.get(3));

cache.put(4, 4); // 去除 key 1

// 返回 -1 (未找到 key 1)

System.out.println(cache.get(1));

// 返回 3

System.out.println(cache.get(3));

// 返回 4

System.out.println(cache.get(4));

}

//緩存 cache

private Map cache;

//存儲頻次和對應雙向鏈表關系的map

private Map> freqMap;

private int capacity;

private int size;

//存儲最小頻次值

private int min;

public LFUCache1(int capacity) {

this.capacity = capacity;

cache = new HashMap<>();

freqMap = new HashMap<>();

}

public int get(int key) {

Node node = cache.get(key);

if(node == null) return -1;

//若找到當前元素,則頻次加1

freqInc(node);

return node.value;

}

public void put(int key, int value) {

if(capacity == 0) return;

Node node = cache.get(key);

if(node != null){

node.value = value;

freqInc(node);

}else{

if(size == capacity){

Node deadNode = removeNode();

cache.remove(deadNode.key);

size --;

}

Node newNode = new Node(key,value);

cache.put(key,newNode);

addNode(newNode);

size++;

}

}

//處理頻次map

private void freqInc(Node node){

//從原來的頻次對應的鏈表中刪除當前node

LinkedHashSet set = freqMap.get(node.freq);

if(set != null)

set.remove(node);

//如果當前頻次是最小頻次,并且移除元素后,鏈表為空,則更新min值

if(node.freq == min && set.size() == 0){

min = node.freq + 1;

}

//添加到新的頻次對應的鏈表

node.freq ++;

LinkedHashSet newSet = freqMap.get(node.freq);

//如果高頻次鏈表還未存在,則初始化一條

if(newSet == null){

newSet = new LinkedHashSet();

freqMap.put(node.freq,newSet);

}

newSet.add(node);

}

//添加元素,更新頻次

private void addNode(Node node){

//添加新元素,肯定是需要加入到頻次為1的鏈表中的

LinkedHashSet set = freqMap.get(1);

if(set == null){

set = new LinkedHashSet<>();

freqMap.put(1,set);

}

set.add(node);

//更新最小頻次為1

min = 1;

}

//刪除頻次最小,最久未訪問的元素

private Node removeNode(){

//找到最小頻次對應的 LinkedHashSet

LinkedHashSet set = freqMap.get(min);

//迭代到的第一個元素就是最久未訪問的元素,移除之

Node node = set.iterator().next();

set.remove(node);

//如果當前node的頻次等于最小頻次,并且移除元素之后,set為空,則 min 加1

if(node.freq == min && set.size() == 0){

min ++;

}

return node;

}

private class Node {

int key;

int value;

int freq = 1;

public Node(int key, int value){

this.key = key;

this.value = value;

}

public Node(){

}

}

}

方案四:手動實現一個頻次鏈表

思路:

由于方案三用的是JDK自帶的 LinkedHashSet ,其是實現了哈希表和雙向鏈表的一個類,因此為了減少哈希相關的計算,提高效率,我們自己實現一條雙向鏈表來替代它。

那么,這條雙向鏈表,就需要維護當前頻次下的所有元素的先后訪問順序。我們采用頭插法,把新加入的元素添加到鏈表頭部,這樣的話,最久未訪問的元素就在鏈表的尾部。

同樣的,我們也用兩個哨兵節點來代表頭尾節點,以方便鏈表的操作。

代碼如下:

public class LFUCache2 {

public static void main(String[] args) {

LFUCache2 cache = new LFUCache2(2);

cache.put(1, 1);

cache.put(2, 2);

// 返回 1

System.out.println(cache.get(1));

cache.put(3, 3); // 去除 key 2

// 返回 -1 (未找到key 2)

System.out.println(cache.get(2));

// 返回 3

System.out.println(cache.get(3));

cache.put(4, 4); // 去除 key 1

// 返回 -1 (未找到 key 1)

System.out.println(cache.get(1));

// 返回 3

System.out.println(cache.get(3));

// 返回 4

System.out.println(cache.get(4));

}

private Map cache;

private Map freqMap;

private int capacity;

private int size;

private int min;

public LFUCache2(int capacity){

this.capacity = capacity;

cache = new HashMap<>();

freqMap = new HashMap<>();

}

public int get(int key){

Node node = cache.get(key);

if(node == null) return -1;

freqInc(node);

return node.value;

}

public void put(int key, int value){

if(capacity == 0) return;

Node node = cache.get(key);

if(node != null){

node.value = value; //更新value值

freqInc(node);

}else{

//若size達到最大值,則移除頻次最小,最久未訪問的元素

if(size == capacity){

//因鏈表是頭插法,所以尾結點的前一個節點就是最久未訪問的元素

DoubleLinkedList list = freqMap.get(min);

//需要移除的節點

Node deadNode = list.tail.pre;

cache.remove(deadNode.key);

list.removeNode(deadNode);

size--;

}

//新建一個node,并把node放到頻次為 1 的 list 里面

Node newNode = new Node(key,value);

DoubleLinkedList newList = freqMap.get(1);

if(newList == null){

newList = new DoubleLinkedList();

freqMap.put(1,newList);

}

newList.addNode(newNode);

cache.put(key,newNode);

size++;

min = 1;//此時需要把min值重新設置為1

}

}

//修改頻次

private void freqInc(Node node){

//先刪除node對應的頻次list

DoubleLinkedList list = freqMap.get(node.freq);

if(list != null){

list.removeNode(node);

}

//判斷min是否等于當前node的頻次,且當前頻次的list為空,是的話更新min值

if(min == node.freq && list.isEmpty()){

min ++;

}

//然后把node頻次加 1,并把它放到高頻次list

node.freq ++;

DoubleLinkedList newList = freqMap.get(node.freq);

if(newList == null){

newList = new DoubleLinkedList();

freqMap.put(node.freq, newList);

}

newList.addNode(node);

}

private class Node {

int key;

int value;

int freq = 1;

Node pre;

Node next;

public Node(){

}

public Node(int key, int value){

this.key = key;

this.value = value;

}

}

//自實現的一個雙向鏈表

private class DoubleLinkedList {

Node head;

Node tail;

// 設置兩個哨兵節點,作為頭、尾節點便于插入和刪除操作

public DoubleLinkedList(){

head = new Node();

tail = new Node();

head.next = tail;

tail.pre = head;

}

//采用頭插法,每次都插入到鏈表的最前面,即 head 節點后邊

public void addNode(Node node){

node.pre = head;

node.next = head.next;

//注意先把head的后節點的前節點設置為node

head.next.pre = node;

head.next = node;

}

//刪除元素

public void removeNode(Node node){

node.pre.next = node.next;

node.next.pre = node.pre;

}

//判斷是否為空,即是否存在除了哨兵節點外的有效節點

public boolean isEmpty(){

//判斷頭結點的下一個節點是否是尾結點,是的話即為空

return head.next == tail;

}

}

}

方案五:用雙向鏈表嵌套

思路:

可以發現方案三和方案四,都是用 freqmap 來存儲頻次和它對應的鏈表之間的關系,它本身也是一個哈希表。這次,我們完全用自己實現的雙向鏈表來代替 freqMap,進一步提高效率。

但是,結構有些復雜,它是一個雙向鏈表中,每個元素又是雙向鏈表。為了便于理解,我把它的結構作圖如下:(為了方便,分別叫做外層鏈表,內層鏈表)

我們把整體看成一個由 DoubleLinkedList組成的雙向鏈表,然后,每一個 DoubleLinkedList 對象中又是一個由 Node 組成的雙向鏈表。像極了 HashMap 數組加鏈表的形式。

但是,我們這里沒有數組,也就不存在哈希碰撞的問題。并且都是雙向鏈表,都有哨兵存在,便于靈活的從鏈表頭部或者尾部開始操作元素。

這里,firstLinkedList 和 lastLinkedList 分別代表外層鏈表的頭尾結點。鏈表中的元素 DoubleLinkedList 有一個字段 freq 記錄了頻次,并且按照前大后小的順序組成外層鏈表,即圖中的 DoubleLinkedList1.freq 大于它后面的 DoubleLinkedList2.freq。

每當有新頻次的 DoubleLinkedList 需要添加進來的時候,直接插入到 lastLinkedList 這個哨兵前面,因此 lastLinkedList.pre 就是一個最小頻次的內部鏈表。

內部鏈表中是由 Node組成的雙向鏈表,也有兩個哨兵代表頭尾節點,并采用頭插法。其實,可以看到內部鏈表和方案四,圖中所示的雙向鏈表結構是一樣的,不用多說了。

這樣的話,我們就可以找到頻次最小,并且最久未訪問的元素,即

//頻次最小,最久未訪問的元素,cache滿時需要刪除

lastLinkedList.pre.tail.pre

于是,代碼就好理解了:

public class LFUCache3 {

public static void main(String[] args) {

LFUCache3 cache = new LFUCache3(2);

cache.put(1, 1);

cache.put(2, 2);

// 返回 1

System.out.println(cache.get(1));

cache.put(3, 3); // 去除 key 2

// 返回 -1 (未找到key 2)

System.out.println(cache.get(2));

// 返回 3

System.out.println(cache.get(3));

cache.put(4, 4); // 去除 key 1

// 返回 -1 (未找到 key 1)

System.out.println(cache.get(1));

// 返回 3

System.out.println(cache.get(3));

// 返回 4

System.out.println(cache.get(4));

}

Map cache;

/**

* 這兩個代表的是以 DoubleLinkedList 連接成的雙向鏈表的頭尾節點,

* 且為哨兵節點。每個list中,又包含一個由 node 組成的一個雙向鏈表。

* 最外層雙向鏈表中,freq 頻次較大的 list 在前面,較小的 list 在后面

*/

DoubleLinkedList firstLinkedList, lastLinkedList;

int capacity;

int size;

public LFUCache3(int capacity){

this.capacity = capacity;

cache = new HashMap<>();

//初始化外層鏈表的頭尾節點,作為哨兵節點

firstLinkedList = new DoubleLinkedList();

lastLinkedList = new DoubleLinkedList();

firstLinkedList.next = lastLinkedList;

lastLinkedList.pre = firstLinkedList;

}

//存儲具體鍵值對信息的node

private class Node {

int key;

int value;

int freq = 1;

Node pre;

Node next;

DoubleLinkedList doubleLinkedList;

public Node(){

}

public Node(int key, int value){

this.key = key;

this.value = value;

}

}

public int get(int key){

Node node = cache.get(key);

if(node == null) return -1;

freqInc(node);

return node.value;

}

public void put(int key, int value){

if(capacity == 0) return;

Node node = cache.get(key);

if(node != null){

node.value = value;

freqInc(node);

}else{

if(size == capacity){

/**

* 如果滿了,則需要把頻次最小的,且最久未訪問的節點刪除

* 由于list組成的鏈表頻次從前往后依次減小,故最小的頻次list是 lastLinkedList.pre

* list中的雙向node鏈表采用的是頭插法,因此最久未訪問的元素是 lastLinkedList.pre.tail.pre

*/

//最小頻次list

DoubleLinkedList list = lastLinkedList.pre;

//最久未訪問的元素,需要刪除

Node deadNode = list.tail.pre;

cache.remove(deadNode.key);

list.removeNode(deadNode);

size--;

//如果刪除deadNode之后,此list中的雙向鏈表空了,則刪除此list

if(list.isEmpty()){

removeDoubleLinkedList(list);

}

}

//沒有滿,則新建一個node

Node newNode = new Node(key, value);

cache.put(key,newNode);

//判斷頻次為1的list是否存在,不存在則新建

DoubleLinkedList list = lastLinkedList.pre;

if(list.freq != 1){

DoubleLinkedList newList = new DoubleLinkedList(1);

addDoubleLinkedList(newList,list);

newList.addNode(newNode);

}else{

list.addNode(newNode);

}

size++;

}

}

//修改頻次

private void freqInc(Node node){

//從當前頻次的list中移除當前 node

DoubleLinkedList list = node.doubleLinkedList;

if(list != null){

list.removeNode(node);

}

//如果當前list中的雙向node鏈表空,則刪除此list

if(list.isEmpty()){

removeDoubleLinkedList(list);

}

//當前node頻次加1

node.freq++;

//找到當前list前面的list,并把當前node加入進去

DoubleLinkedList preList = list.pre;

//如果前面的list不存在,則新建一個,并插入到由list組成的雙向鏈表中

//前list的頻次不等于當前node頻次,則說明不存在

if(preList.freq != node.freq){

DoubleLinkedList newList = new DoubleLinkedList(node.freq);

addDoubleLinkedList(newList,preList);

newList.addNode(node);

}else{

preList.addNode(node);

}

}

//從外層雙向鏈表中刪除當前list節點

public void removeDoubleLinkedList(DoubleLinkedList list){

list.pre.next = list.next;

list.next.pre = list.pre;

}

//知道了它的前節點,即可把新的list節點插入到其后面

public void addDoubleLinkedList(DoubleLinkedList newList, DoubleLinkedList preList){

newList.pre = preList;

newList.next = preList.next;

preList.next.pre = newList;

preList.next = newList;

}

//維護一個雙向DoubleLinkedList鏈表 + 雙向Node鏈表的結構

private class DoubleLinkedList {

//當前list中的雙向Node鏈表所有頻次都相同

int freq;

//當前list中的雙向Node鏈表的頭結點

Node head;

//當前list中的雙向Node鏈表的尾結點

Node tail;

//當前list的前一個list

DoubleLinkedList pre;

//當前list的后一個list

DoubleLinkedList next;

public DoubleLinkedList(){

//初始化內部鏈表的頭尾節點,并作為哨兵節點

head = new Node();

tail = new Node();

head.next = tail;

tail.pre = head;

}

public DoubleLinkedList(int freq){

head = new Node();

tail = new Node();

head.next = tail;

tail.pre = head;

this.freq = freq;

}

//刪除當前list中的某個node節點

public void removeNode(Node node){

node.pre.next = node.next;

node.next.pre = node.pre;

}

//頭插法將新的node插入到當前list,并在新node中記錄當前list的引用

public void addNode(Node node){

node.pre = head;

node.next = head.next;

head.next.pre = node;

head.next = node;

node.doubleLinkedList = this;

}

//當前list中的雙向node鏈表是否存在有效節點

public boolean isEmpty(){

//只有頭尾哨兵節點,則說明為空

return head.next == tail;

}

}

}

由于,此方案全是鏈表的增刪操作,因此時間復雜度可到 O(1)。

結語

終于總結完了,其實,感覺思想搞明白了,代碼實現起來就相對容易一些。但是,還是需要多寫,多實踐。過段時間再來回顧一下~

總結

以上是生活随笔為你收集整理的lfu算法实现java_LFU五种实现方式,从简单到复杂的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久久久久国产精品免费 | 丝袜足交在线 | 免费在线电影网址大全 | 欧美一区二区三区在线视频观看 | 五月天婷婷免费视频 | 激情网站网址 | 大荫蒂欧美视频另类xxxx | 一级黄色a视频 | 在线观看香蕉视频 | 天天操天天曰 | 日韩欧美黄色网址 | 成人一区影院 | 日韩va在线观看 | 在线观看91精品国产网站 | 91视频在线免费看 | av中文字幕av| 国产亚洲精品久久久久动 | av电影中文 | 久久综合免费视频影院 | 亚洲va欧美va人人爽春色影视 | 一区二区不卡视频在线观看 | 夜夜视频欧洲 | 亚洲国产最新 | 成人黄色毛片 | www.亚洲精品视频 | 看国产黄色片 | 国产精品完整版 | 91亚洲狠狠婷婷综合久久久 | 黄色大片日本免费大片 | 久久在线 | www.狠狠插.com | 婷婷av网站 | 亚洲理论片在线观看 | 五月综合网站 | 国产中文在线字幕 | 天天激情天天干 | 久久久久免费精品国产小说色大师 | 免费色av| 国产精品久久久久一区二区国产 | 国产亚洲视频在线免费观看 | 91九色蝌蚪国产 | 日韩一区二区免费视频 | 91精品欧美一区二区三区 | 99一区二区三区 | 免费日韩 精品中文字幕视频在线 | 国产黄色片在线免费观看 | 蜜臀久久99精品久久久无需会员 | 伊人六月 | 国产亚洲精品久久久久久久久久久久 | 成人性生交大片免费观看网站 | 国产+日韩欧美 | 97在线观看免费观看 | 久久精品com| 99视频精品免费视频 | 91高清不卡 | 一区二区三区视频网站 | 91干干干| 日韩欧美视频免费看 | 欧美精品亚州精品 | 中文字幕第一页在线播放 | 夜夜操网 | 伊人伊成久久人综合网小说 | 亚洲免费av观看 | 91视频免费看网站 | 天天操天天干天天操天天干 | 天天爱天天操天天爽 | 国产中文在线观看 | 国产精品久久嫩一区二区免费 | 久久久久福利视频 | 午夜免费福利视频 | 精品国自产在线观看 | 狠狠干成人综合网 | 国产在线小视频 | 国产人成看黄久久久久久久久 | 超碰97在线资源 | 色婷婷久久一区二区 | 美女久久久久久久久久久 | 免费色网站 | 黄色精品久久 | 亚洲欧洲精品一区二区 | 一区二区三区观看 | 在线观看视频免费大全 | 国产精品99久久久久久人免费 | 久久国产一区二区三区 | 99超碰在线观看 | 中文字幕在线看 | 国产精品一区二区三区在线免费观看 | 91亚洲精品久久久 | 在线观看视频你懂 | 久久观看免费视频 | 成人九九视频 | 亚洲精品国产区 | 黄色www在线观看 | 天堂入口网站 | 婷婷久久五月 | 九九色在线观看 | 91亚洲狠狠婷婷综合久久久 | 69欧美视频| 91x色| 天天综合中文 | 亚洲国产中文字幕在线视频综合 | 激情伊人五月天久久综合 | 日本成人免费在线观看 | 在线观看视频在线观看 | 久久久久久久久影院 | 中文字幕在线观看视频免费 | 亚洲黄色片在线 | 亚洲视频在线观看 | 欧美高清视频不卡网 | 欧美日韩成人 | 91成人黄色| 一区二区成人国产精品 | 四虎国产精品免费 | 成人精品电影 | 久久久在线免费观看 | 国产录像在线观看 | 狠狠色噜噜狠狠 | 久久人91精品久久久久久不卡 | 日韩网页 | 91xav| 亚洲永久精品视频 | 在线视频欧美亚洲 | 日韩视频在线观看视频 | 久久亚洲欧美日韩精品专区 | 丁香婷婷激情国产高清秒播 | 国产欧美综合在线观看 | 免费 在线 中文 日本 | 91视频成人免费 | 国产日韩中文字幕 | 色永久免费视频 | 五月婷婷激情综合 | 久久精品欧美 | 麻豆一区在线观看 | 嫩草伊人久久精品少妇av | 特级西西444www大精品视频免费看 | 亚洲三级黄色 | 成年人在线观看 | 中文字幕的 | 亚洲一区免费在线 | 欧美日韩在线观看一区二区 | 婷婷丁香花五月天 | 亚洲欧美在线观看视频 | 久久免费视频7 | 久久99国产一区二区三区 | 成人aaa毛片| 中文字幕高清 | 色吊丝av中文字幕 | 国产精品久久久久久一区二区三区 | 99九九99九九九视频精品 | 中文不卡视频在线 | 国产一区二区三区在线免费观看 | 久久在线看 | 亚洲每日更新 | 国产91免费在线 | 国产精品成人一区二区 | 免费在线观看中文字幕 | 九九精品视频在线看 | 国产成人久久av977小说 | 欧美日韩免费网站 | 在线观看久久久久久 | 亚洲成人午夜av | 久久精品欧美一区 | 久久成人麻豆午夜电影 | a级国产乱理论片在线观看 特级毛片在线观看 | av福利超碰网站 | 麻豆国产在线视频 | 波多野结衣一区三区 | 免费看毛片网站 | 三级av片 | 亚洲午夜av久久乱码 | 免费在线观看不卡av | 精品亚洲免费视频 | 国产精品一区二区无线 | 欧美99久久| 久久精品美女视频 | 亚洲国产一区在线观看 | 狠狠婷婷| 国产成人在线综合 | 69亚洲视频 | 日韩一级片网址 | 一区二区中文字幕在线观看 | 干狠狠| 成人免费观看a | 国内少妇自拍视频一区 | 国产成人久久久77777 | 99久久精品视频免费 | 狠狠干天天干 | 日本性久久 | 国产视频不卡一区 | 69人人| 国产成人久久精品亚洲 | 日韩高清激情 | av免费在线观看1 | 精品欧美一区二区精品久久 | 亚洲国产成人av网 | 玖玖综合网 | 色综合久久精品 | 91精品在线麻豆 | 久久久久高清毛片一级 | 久久精品国产精品亚洲精品 | 日本一区二区不卡高清 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 毛片视频电影 | 午夜123| 久久久激情视频 | 久久免费黄色 | 国产精品毛片久久久久久久久久99999999 | 久久精品波多野结衣 | 亚洲做受高潮欧美裸体 | 国产一区二区三区视频在线 | 日韩亚洲在线 | 国产中文自拍 | 在线91观看 | 国产精品 中文字幕 亚洲 欧美 | 天天躁日日躁狠狠躁av中文 | 国产香蕉av | 久久国产精品久久w女人spa | 国产精品一区免费看8c0m | avwww在线 | 五月婷婷六月丁香在线观看 | 久久久久久久久久伊人 | 91精品国产一区二区在线观看 | 亚洲精品国产精品久久99热 | 久草国产在线 | 麻豆传媒视频在线 | 国产在线观看 | 色av色av色av| 亚洲精品国产区 | 亚洲欧美视频在线观看 | 亚洲黑丝少妇 | 国产自在线 | 九九九电影免费看 | 国产成人黄色片 | 国产精品一区二区三区久久久 | 特黄特色特刺激视频免费播放 | 亚洲国产69 | 亚欧日韩成人h片 | 在线 视频 亚洲 | 伊人狠狠操| 丝袜网站在线观看 | 国产91成人在在线播放 | 2023亚洲精品国偷拍自产在线 | 伊人久久精品久久亚洲一区 | 999视频在线观看 | 国产一区二区在线免费观看 | 亚洲美女视频网 | 国产麻豆果冻传媒在线观看 | 国产裸体无遮挡 | 亚洲精品国产综合99久久夜夜嗨 | 中文字幕av在线播放 | av千婊在线免费观看 | 成人午夜剧场在线观看 | 欧美乱熟臀69xxxxxx | 日韩在线色 | 久久久精品国产一区二区电影四季 | 欧美国产日韩中文 | 午夜精选视频 | 日韩成人精品 | 日韩欧美成 | 国产精品理论视频 | 黄色av电影一级片 | 日韩欧美国产精品 | 久草资源在线 | 96亚洲精品久久久蜜桃 | 国产亚洲日本 | 日韩电影中文字幕 | 日韩在线电影一区二区 | 日本中文在线 | 免费黄a大片 | 黄av免费在线观看 | 美女网站在线看 | 日韩视频免费观看高清完整版在线 | 成人资源在线 | 欧美精品xx | 极品嫩模被强到高潮呻吟91 | 欧美日韩在线视频观看 | 99久热在线精品 | 日韩| 亚洲专区在线播放 | 中文字幕亚洲精品在线观看 | 99久久er热在这里只有精品66 | 日本成人中文字幕在线观看 | 日韩av二区 | 国产精品福利av | 丝袜美腿亚洲 | 人人干人人超 | 免费网站污 | 中文字幕一区2区3区 | 精品久久久久久久久中文字幕 | 久久精品视频在线看 | 欧美日韩在线电影 | 国产日本亚洲高清 | 久操操| av中文天堂在线 | 99免费精品视频 | 麻豆影视网站 | 91视频亚洲 | 天堂视频一区 | 国产亚洲精品美女久久 | 欧美一二三视频 | 中文字幕在线第一页 | 国产精品青草综合久久久久99 | 欧美精品九九 | 日韩激情一二三区 | 日韩成人在线免费观看 | 久视频在线播放 | 91在线视频免费播放 | 久热超碰 | 最新久久免费视频 | 日韩高清www | 婷婷色伊人 | a天堂中文在线 | 色福利网站 | 中文字幕亚洲欧美日韩 | 黄污网 | 成人午夜剧场在线观看 | 特级毛片在线观看 | 一性一交视频 | 97超在线视频 | 在线亚洲播放 | www在线免费观看 | 狠狠色狠狠色综合日日92 | 国产黄色精品在线观看 | 五月天九九 | 超碰最新网址 | 亚洲一区不卡视频 | 久青草电影 | 香蕉视频日本 | 久草视频在线免费播放 | 色综合天天综合网国产成人网 | 亚洲专区在线视频 | 国产成人在线综合 | 亚洲午夜久久久影院 | 毛片的网址 | 免费人成在线观看网站 | 国精产品999国精产品视频 | 99精品欧美一区二区蜜桃免费 | 国产粉嫩在线观看 | 国产综合久久 | 日韩精品久久久免费观看夜色 | 亚洲成人资源在线 | 成人av免费在线观看 | 五月情婷婷 | 在线看一区二区 | 欧美激情视频一区二区三区免费 | 久久人人爽人人人人片 | 亚洲成人动漫在线观看 | 欧美高清视频不卡网 | 久久精品视频播放 | 999成人| 中文字幕在线一区观看 | 久久香蕉国产精品麻豆粉嫩av | 国产成人福利在线 | 美女精品在线观看 | 99夜色 | 日本中文在线 | 国产明星视频三级a三级点| 色激情五月 | 久久久久五月 | 一区二区激情 | 日韩高清三区 | 亚洲国产精品女人久久久 | 久久精品视频网站 | 黄色国产高清 | 国产aa免费视频 | 欧美一区成人 | 久久人人爽人人爽人人片av软件 | 在线国产能看的 | 精品一区二区三区久久 | 看全黄大色黄大片 | 狠狠色狠狠色终合网 | 久久婷婷综合激情 | 国产精品欧美一区二区三区不卡 | 日韩欧美视频免费在线观看 | 中文字幕在线乱 | 高清av网 | 午夜视频在线观看一区二区三区 | 91在线你懂的 | 91av美女| 六月丁香久久 | 天天射网站 | 成人精品国产免费网站 | 麻豆手机在线 | 精品免费视频 | 久久综合久久综合久久综合 | av 一区二区三区四区 | 特级毛片在线免费观看 | 十八岁免进欧美 | 国产区欧美 | 国产乱码精品一区二区蜜臀 | 在线性视频日韩欧美 | 麻豆系列在线观看 | 国产美腿白丝袜足在线av | 久久人人爽爽 | 久久久久国产成人精品亚洲午夜 | 九色视频网站 | 亚洲免费观看视频 | 国产一级二级三级在线观看 | 伊人国产视频 | 久久亚洲欧美日韩精品专区 | 91最新中文字幕 | 九九久久精品视频 | 亚洲a免费| 久久久久欧美精品 | 亚洲电影第一页av | 免费在线激情视频 | 天天弄天天操 | 另类五月激情 | 国产一级做a | 亚洲一区美女视频在线观看免费 | 国产精品国产三级国产不产一地 | 免费视频一区 | 天天干天天天天 | 久久黄页| 成人高清在线观看 | 婷婷久久网站 | 国产一区二区三区在线免费观看 | 亚洲伦理一区 | 亚洲精品国偷拍自产在线观看蜜桃 | 四虎伊人 | 亚洲天天摸日日摸天天欢 | 欧美一区成人 | 最新国产中文字幕 | 国产精品一区二区吃奶在线观看 | 91久久一区二区 | 成人久久久精品国产乱码一区二区 | 九九在线国产视频 | 成人免费视频免费观看 | 日韩中文字幕视频在线 | 精品国产免费久久 | 五月天婷婷综合 | 欧美天天综合 | 久久污视频 | 国产精品一区二区在线观看免费 | 午夜三级毛片 | 狠狠干天天射 | 色婷婷免费视频 | 日韩中文字幕免费在线观看 | 91av视频导航 | 91.dizhi永久地址最新 | 天天干天天做天天爱 | 狠狠ri| 超碰在线资源 | 婷婷亚洲最大 | 日b视频在线观看网址 | 欧美激情视频一区二区三区免费 | 免费在线观看的av网站 | www.五月天婷婷.com | 97精品国产| 国产精品色婷婷 | 日韩黄色在线观看 | av中文天堂在线 | 欧美一二三区播放 | 99久久综合精品五月天 | 制服丝袜天堂 | 日韩a欧美| 视频在线99re| 91日韩精品 | 久久综合九色综合欧美狠狠 | 日本护士三级少妇三级999 | 成人黄色电影免费观看 | 日韩资源视频 | 国产精品毛片久久蜜 | 欧美日韩亚洲在线观看 | 麻豆国产视频下载 | 中文字幕日韩国产 | 草莓视频在线观看免费观看 | 久久成人国产精品 | 午夜狠狠干 | 久久网站最新地址 | 日韩最新理论电影 | 黄色大片日本免费大片 | 丁香婷婷久久 | 99久久国产免费免费 | 13日本xxxxxⅹxxx20 | 一区二区三区免费在线观看视频 | 国产h在线观看 | 波多野结衣在线观看一区 | 97在线影视 | 亚洲欧美国产精品久久久久 | 美女视频网站久久 | 久久激情视频 久久 | 久久精品国产一区二区 | 成人a v视频 | 精品麻豆入口免费 | 天天爽夜夜操 | 91精品夜夜 | 久久精品人 | 51久久成人国产精品麻豆 | 国产在线观看xxx | 黄色网www | 黄色片网站 | 乱子伦av | 国产在线观看高清视频 | 四虎免费av | 国产黄在线看 | 99久久精品日本一区二区免费 | 亚洲污视频 | 免费观看视频黄 | 99久久综合精品五月天 | 在线观看视频黄 | 欧美日韩成人 | 西西大胆啪啪 | 日韩免费电影 | 国产亚洲视频在线 | 亚洲成人影音 | 夜夜爽88888免费视频4848 | 人人要人人澡人人爽人人dvd | 久久久www成人免费毛片麻豆 | 国产中文字幕久久 | 国产在线播放一区二区三区 | 久久久国产精品亚洲一区 | www.日本色 | 国产一级片一区二区三区 | 91福利在线导航 | 久久久久成人免费 | 免费看黄色毛片 | 91福利视频免费观看 | 久久综合婷婷国产二区高清 | 精品久久久久久久久久久久久久久久 | 色综合天天天天做夜夜夜夜做 | 亚洲免费av在线播放 | 亚洲精品99久久久久中文字幕 | 亚洲欧美婷婷六月色综合 | 国产午夜精品免费一区二区三区视频 | 色婷婷啪啪免费在线电影观看 | 国产99久久久精品 | www.香蕉视频在线观看 | 精品在线一区二区三区 | 色婷婷一区 | 精品国产欧美一区二区三区不卡 | 视频99爱 | 韩国av一区二区三区 | 99在线播放 | 色视频在线免费 | 国产黄色一级片在线 | 91热| avwww在线观看 | 在线观看视频一区二区三区 | 91成年人视频 | 九九九热精品免费视频观看网站 | 最近中文字幕大全中文字幕免费 | 99草在线视频 | 国内揄拍国内精品 | 亚洲国产成人久久 | 国产精品久久久免费看 | 91视频免费观看 | 在线精品亚洲一区二区 | 福利视频导航网址 | 亚洲爱视频 | 欧美另类xxxx | 韩国av电影网 | 国产一区二区不卡视频 | 天堂素人在线 | 日本精品二区 | 亚洲 欧美 变态 国产 另类 | 精品一区二区三区久久久 | 午夜精品福利一区二区三区蜜桃 | 九九视频精品免费 | 精品国产一区二区三区久久 | 最近中文字幕国语免费av | 国产精品黑丝在线观看 | 精品日韩在线一区 | 免费在线播放av电影 | 精品麻豆 | 国产视频网站在线观看 | 最新国产精品久久精品 | 中文字幕字幕中文 | 久久女同性恋中文字幕 | 在线观看中文字幕第一页 | 四川bbb搡bbb爽爽视频 | 国产精品女教师 | 久久av中文字幕片 | 亚洲 欧美 另类人妖 | 色中色亚洲| 精品国产aⅴ一区二区三区 在线直播av | 亚洲国产成人精品电影在线观看 | 国产精品婷婷 | 国产日本三级 | 81精品国产乱码久久久久久 | 激情五月六月婷婷 | 99久久精品免费看国产一区二区三区 | 99色在线视频 | 久久精品99国产国产 | 久久高清免费观看 | 97在线免费 | 狠狠色丁香婷婷综合久小说久 | 免费久久精品视频 | 国产精品亚洲精品 | 久久丁香网| 日韩免费在线网站 | 日韩三级免费 | 亚洲性xxxx | 天天玩夜夜操 | 久久夜色精品国产欧美一区麻豆 | 国产精品一区二区在线播放 | 免费高清在线一区 | 中文字幕乱码日本亚洲一区二区 | 在线观看香蕉视频 | 亚洲一级二级三级 | 蜜桃视频日本 | 亚洲精品永久免费视频 | 草久久av | 色婷婷在线播放 | 91成人破解版 | 9992tv成人免费看片 | 美女黄濒 | 一区二区三区电影 | 婷婷久久一区二区三区 | 国产特黄色片 | 97人人射 | 午夜私人影院久久久久 | 欧美久久久久久久久久久 | av亚洲产国偷v产偷v自拍小说 | 99精品视频免费观看 | 国产精品你懂的在线观看 | 中文字幕av免费在线观看 | 久久综合99| 亚洲精品一区二区三区高潮 | 日韩专区av| 91久久国产自产拍夜夜嗨 | 久久综合九色99 | 日韩在线视频一区二区三区 | 国产第一页精品 | 四虎天堂 | a视频在线观看 | va视频在线 | 日韩中文字幕在线观看 | 亚洲乱码精品 | 日日夜夜天天久久 | 九九九九热精品免费视频点播观看 | 欧美xxxx性xxxxx高清 | 天天操天天干天天干 | 成人h视频在线播放 | 午夜视频黄 | 一级成人在线 | 黄色网在线播放 | www.97视频| 一区二区三区视频网站 | 欧美在线18| 黄色午夜| 国产精品美女久久久久久久 | 久草免费在线 | 91精品国产一区二区在线观看 | 亚洲伦理中文字幕 | 波多野结衣在线观看视频 | 午夜在线免费观看 | 国产99在线 | 国产一级片在线播放 | 超碰在线观看av.com | 中文字幕一区二区三区久久蜜桃 | 五月天久久 | 久久久资源 | 在线观看av国产 | 午夜久久网站 | 成人久久影院 | av中文资源在线 | a级国产乱理伦片在线播放 久久久久国产精品一区 | 91传媒激情理伦片 | 亚洲另类视频 | 久久久久久久久免费视频 | 国产一级黄色电影 | 91久久人澡人人添人人爽欧美 | 免费欧美| 国产一级一级国产 | 久久免费播放 | 国产精品porn | 免费高清无人区完整版 | 精品国产成人av在线免 | 色婷婷骚婷婷 | 国产手机视频精品 | 久久综合色婷婷 | 免费看污片| 日韩大片在线观看 | 色综合夜色一区 | 亚洲国产手机在线 | 欧美资源 | 国产成人久久av免费高清密臂 | 欧美精品免费在线观看 | 免费情缘| 五月开心综合 | 午夜国产一区二区 | 国产99久久久精品 | 欧美精品亚州精品 | 免费看国产曰批40分钟 | 中国一级特黄毛片大片久久 | 在线观看视频黄色 | 国产精品九九九九九九 | 日韩中文字幕在线观看 | 免费观看国产成人 | 在线观看国产永久免费视频 | 丁香花在线视频观看免费 | 国产午夜精品理论片在线 | 午夜少妇一区二区三区 | 麻豆综合网 | 国产电影黄色av | 美女黄频在线观看 | 欧美 亚洲 另类 激情 另类 | 成人综合婷婷国产精品久久免费 | 亚洲成人影音 | 日韩av综合网站 | 欧美夫妻生活视频 | 免费日韩一区二区三区 | 麻花豆传媒mv在线观看网站 | 免费午夜在线视频 | 欧美日韩二区在线 | 又黄又爽又刺激 | 亚洲精品视频一二三 | 一区二区精品视频 | 久久久久久久久艹 | 色在线最新 | 波多野结衣在线播放一区 | 狠狠狠色丁香婷婷综合久久五月 | 国产精品免费在线播放 | 午夜av大片 | 国产欧美中文字幕 | 91精品婷婷国产综合久久蝌蚪 | 91丨九色丨国产在线观看 | 久久久首页 | 五月综合激情 | 婷婷六月丁香激情 | 99精品视频免费观看视频 | 日韩免费视频一区二区 | www.日本色 | 亚洲国产午夜视频 | 久久久国产一区 | 亚洲国产剧情av | 欧美一级乱黄 | 777视频在线观看 | 天天操天天干天天 | 日本色小说视频 | 999精品视频 | 国产无限资源在线观看 | 99久久婷婷 | 在线观看播放av | 婷婷综合伊人 | 午夜精品福利在线 | 伊人中文网 | 不卡电影一区二区三区 | 97在线精品国自产拍中文 | 国产99久久九九精品免费 | 国产精品久久久久久一区二区 | 久久蜜臀一区二区三区av | 成人试看120秒 | japanesexxxxfreehd乱熟 | 91麻豆精品一区二区三区 | 婷婷六月天综合 | 黄色午夜网站 | 久久婷亚洲五月一区天天躁 | 色综合夜色一区 | 久产久精国产品 | 日韩在线激情 | 丁香九月激情综合 | 香蕉视频在线看 | 高清国产一区 | 超碰国产97 | 国产超碰在线 | 超碰公开在线 | 国产 日韩 在线 亚洲 字幕 中文 | 在线播放一区二区三区 | 97视频资源| 国产在线观看高清视频 | 天天操夜夜操 | 久久免费试看 | 色婷婷国产在线 | 免费在线成人av | 国产精品高清在线观看 | 精品一二区 | 五月天激情综合网 | 九九交易行官网 | 国产高清不卡在线 | 97国产在线播放 | 午夜色站 | 久久国产精品成人免费浪潮 | 日本精品视频在线播放 | 国产小视频在线观看 | 成人影视免费看 | 亚洲成av人片一区二区梦乃 | 久久在草 | 国产精品一区免费在线观看 | 81精品国产乱码久久久久久 | 91看成人 | 99综合视频 | 免费成人在线观看 | 这里有精品在线视频 | 射射射av| 午夜狠狠操 | 中文字幕婷婷 | 一区二区三区视频在线 | 久久人人爽人人爽人人片av软件 | 免费一级特黄录像 | 欧洲精品视频一区二区 | 五月天精品视频 | 999男人的天堂 | 国产成人久久精品77777综合 | 中文字幕中文字幕在线中文字幕三区 | 在线观看午夜av | 亚洲一区二区天堂 | 久99久中文字幕在线 | 高清av影院| 亚洲尺码电影av久久 | 欧美夫妻生活视频 | www.色午夜,com| 996久久国产精品线观看 | 香蕉免费在线 | 国产免费黄视频在线观看 | 五月天高清欧美mv | 五月天伊人网 | 欧美成人h版在线观看 | 久久精品中文字幕免费mv | 99精品视频免费 | 五月天,com| 人人干人人艹 | 国产精品99蜜臀久久不卡二区 | 视频在线99re| 久久观看最新视频 | 久久久久久久国产精品影院 | a久久免费视频 | 91手机视频在线 | 精品久久国产一区 | 天堂网一区二区 | 91看片在线观看 | 一 级 黄 色 片免费看的 | 99视频在线| 91精品小视频 | 99午夜| 最近最新最好看中文视频 | 欧美日韩久久一区 | 成人毛片网 | 国产精品18videosex性欧美 | 精品99久久久久久 | 婷婷网站天天婷婷网站 | 欧美日韩在线视频免费 | 免费黄色av | 在线观看视频一区二区三区 | 中文在线8新资源库 | 国产原创91 | 99精品欧美一区二区 | 国产精品免费观看视频 | 欧美二区视频 | av解说在线观看 | 久精品视频免费观看2 | 又长又大又黑又粗欧美 | 91精品免费在线视频 | 五月天九九 | 在线中文字幕av观看 | 美女国内精品自产拍在线播放 | 婷婷香蕉 | 看毛片的网址 | www.国产高清 | 丝袜制服综合网 | 日黄网站 | 精品国产一二三 | 婷婷六月中文字幕 | 亚洲日韩欧美一区二区在线 | 夜夜躁狠狠躁日日躁视频黑人 | 成人免费在线播放 | 国产精品黄色影片导航在线观看 | 日本久久精品视频 | 亚洲国产成人精品在线 | 日韩精品一卡 | 97超在线| 国内精品久久久久国产 | 日日麻批40分钟视频免费观看 | 婷婷五月色综合 | 国产精品久久 | 亚洲一级国产 | 不卡的av电影在线观看 | 中文字幕国产在线 | 久久图 | 韩日色视频 | 在线看小早川怜子av | 久久看视频 | 国产999精品久久久影片官网 | 中文字幕精品一区二区精品 | 久久99婷婷| 毛片的网址 | 成人国产精品一区二区 | 91精品国产成人观看 | 五月天狠狠操 | 国产精品va最新国产精品视频 | 国产亚洲精品久久久久久移动网络 | 色综合久久精品 | 久久中文字幕在线视频 | 中文字幕在线视频一区二区三区 | 国产精品一区二区三区久久久 | 97视频免费在线观看 | 欧美午夜精品久久久久 | 97超视频在线观看 | 国产电影一区二区三区四区 | 亚洲aⅴ久久精品 | 久久国产精品久久久久 | 99久久免费看 | 永久免费精品视频 | 国产精品午夜免费福利视频 | 91精品国产自产在线观看永久 | 国产视频一 | 久久经典视频 | 91精品爽啪蜜夜国产在线播放 | 日韩成人免费在线电影 | 黄色免费在线视频 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 欧美狠狠色 | 国内精品在线看 | 免费麻豆网站 | 日韩欧美亚洲 | 亚洲 成人 一区 | 波多野结衣视频网址 | 激情婷婷综合网 | 国产精品99久久久精品免费观看 | 国产不卡在线 | 色播六月天 | 成人影视免费看 | 天天干天天干天天干 | 亚洲一区二区三区四区在线视频 | 久久综合中文字幕 | 久久99精品久久久久婷婷 | 精品播放| 丁香婷婷激情啪啪 | 亚洲精品乱码白浆高清久久久久久 | 99热这里只有精品1 av中文字幕日韩 | 亚洲国产日韩av | 91麻豆国产福利在线观看 | 欧美日韩国产精品一区二区三区 | 五月激情亚洲 | av免费在线免费观看 | 91在线看| 国产精品九九热 | 中文字幕成人一区 | 婷婷视频在线 | 色综合天天综合 | 欧美一级裸体视频 | 欧美一区二区精美视频 | 干干日日 | 一区二区视频在线观看免费 | 蜜桃视频精品 | 国产看片网站 | 亚洲黄色在线免费观看 | 国产成人精品一区二区 | 久久久久一区二区三区四区 | 日韩av男人的天堂 | 夜夜夜精品 | av大片免费 | 久久经典视频 | 午夜精品一区二区三区在线观看 | 美女国产精品 | 久久黄色a级片 | 免费av在 | 奇米影视777四色米奇影院 | 国产精品免费在线观看视频 | 免费观看全黄做爰大片国产 | 久久久精品二区 | avsex| 精品1区2区3区 | 97韩国电影 | 欧美国产大片 | 依人成人综合网 | 日韩电影中文,亚洲精品乱码 | 日本不卡123区 | 在线一区观看 | 中文在线字幕免 | 91在线视频免费91 | 久久免费成人精品视频 | 国产精品视频999 | 97超碰在线免费 | 中文字幕日本在线 | 四虎影视成人精品国库在线观看 | 视频成人永久免费视频 | 综合网天天射 | 国产a精品| 欧美a级一区二区 | 三级av免费观看 | 国产精品专区在线观看 | 91麻豆精品91久久久久同性 | 国产亚洲免费观看 | 日韩高清观看 | 日韩理论在线观看 | 91视频在线免费看 | 国产毛片aaa| 一级理论片在线观看 | 中文字幕观看视频 | 五月婷婷另类国产 | 国产一区二区三区免费视频 | 91九色porny在线 | 免费h精品视频在线播放 | 国产最新视频在线观看 | 五月婷婷六月丁香 | 婷婷久久五月天 | 日韩在线视频网站 | 国产91在线观看 | 日本精品一区二区三区在线播放视频 | 视频三区 | 青草视频在线播放 | 久久久精品国产免费观看同学 | 亚洲不卡av一区二区三区 | 中文字幕资源网在线观看 | av一级片 | 国产一级a毛片视频爆浆 |