亚洲国产第一站精品蜜芽_亚洲AV无码精品色午夜果冻不卡_国产香蕉九九久久精品免费_国产精品亚洲专区无码不卡

更多精彩內(nèi)容,歡迎關(guān)注:

視頻號
視頻號

抖音
抖音

快手
快手

微博
微博

當(dāng)前位置:首頁 科技百科 桶排序

桶排序

文檔

桶排序

桶排序是計數(shù)排序的升級版。它利用了函數(shù)的映射關(guān)系,高效與否的關(guān)鍵就在于這個映射函數(shù)的確定。
推薦度:
導(dǎo)讀桶排序是計數(shù)排序的升級版。它利用了函數(shù)的映射關(guān)系,高效與否的關(guān)鍵就在于這個映射函數(shù)的確定。
.example-btn{color:#fff;background-color:#5cb85c;border-color:#4cae4c}.example-btn:hover{color:#fff;background-color:#47a447;border-color:#398439}.example-btn:active{background-image:none}div.example{width:98%;color:#000;background-color:#f6f4f0;background-color:#d0e69c;background-color:#dcecb5;background-color:#e5eecc;margin:0 0 5px 0;padding:5px;border:1px solid #d4d4d4;background-image:-webkit-linear-gradient(#fff,#e5eecc 100px);background-image:linear-gradient(#fff,#e5eecc 100px)}div.example_code{line-height:1.4em;width:98%;background-color:#fff;padding:5px;border:1px solid #d4d4d4;font-size:110%;font-family:Menlo,Monaco,Consolas,"Andale Mono","lucida console","Courier New",monospace;word-break:break-all;word-wrap:break-word}div.example_result{background-color:#fff;padding:4px;border:1px solid #d4d4d4;width:98%}div.code{width:98%;border:1px solid #d4d4d4;background-color:#f6f4f0;color:#444;padding:5px;margin:0}div.code div{font-size:110%}div.code div,div.code p,div.example_code p{font-family:"courier new"}pre{margin:15px auto;font:12px/20px Menlo,Monaco,Consolas,"Andale Mono","lucida console","Courier New",monospace;white-space:pre-wrap;word-break:break-all;word-wrap:break-word;border:1px solid #ddd;border-left-width:4px;padding:10px 15px}

排序算法是《數(shù)據(jù)結(jié)構(gòu)與算法》中最基本的算法之一。排序算法可以分為內(nèi)部排序和外部排序,內(nèi)部排序是數(shù)據(jù)記錄在內(nèi)存中進(jìn)行排序,而外部排序是因排序的數(shù)據(jù)很大,一次不能容納全部的排序記錄,在排序過程中需要訪問外存。常見的內(nèi)部排序算法有:插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數(shù)排序等。以下是桶排序算法:

桶排序是計數(shù)排序的升級版。它利用了函數(shù)的映射關(guān)系,高效與否的關(guān)鍵就在于這個映射函數(shù)的確定。為了使桶排序更加高效,我們需要做到這兩點:

在額外空間充足的情況下,盡量增大桶的數(shù)量使用的映射函數(shù)能夠?qū)⑤斎氲?N 個數(shù)據(jù)均勻的分配到 K 個桶中

同時,對于桶中元素的排序,選擇何種比較排序算法對于性能的影響至關(guān)重要。

1. 什么時候最快

當(dāng)輸入的數(shù)據(jù)可以均勻的分配到每一個桶中。

2. 什么時候最慢

當(dāng)輸入的數(shù)據(jù)被分配到了同一個桶中。

3. 示意圖

元素分布在桶中:

然后,元素在每個桶中排序:

代碼實現(xiàn)JavaScript實例 function bucketSort(arr, bucketSize) {? ? if (arr.length === 0) {? ? ? return arr;? ? }? ? var i;? ? var minValue = arr[0];? ? var maxValue = arr[0];? ? for (i = 1; i < arr.length; i++) {? ? ? if (arr[i] < minValue) {? ? ? ? ? minValue = arr[i]; ? ? ? ? ? ? ? ?// 輸入數(shù)據(jù)的最小值? ? ? } else if (arr[i] > maxValue) {? ? ? ? ? maxValue = arr[i]; ? ? ? ? ? ? ? ?// 輸入數(shù)據(jù)的最大值? ? ? }? ? }? ? //桶的初始化? ? var DEFAULT_BUCKET_SIZE = 5; ? ? ? ? ? ?// 設(shè)置桶的默認(rèn)數(shù)量為5? ? bucketSize = bucketSize || DEFAULT_BUCKET_SIZE;? ? var bucketCount = Math.floor((maxValue - minValue) / bucketSize) + 1; ? ? ? var buckets = new Array(bucketCount);? ? for (i = 0; i < buckets.length; i++) {? ? ? ? buckets[i] = [];? ? }? ? //利用映射函數(shù)將數(shù)據(jù)分配到各個桶中? ? for (i = 0; i < arr.length; i++) {? ? ? ? buckets[Math.floor((arr[i] - minValue) / bucketSize)].push(arr[i]);? ? }? ? arr.length = 0;? ? for (i = 0; i < buckets.length; i++) {? ? ? ? insertionSort(buckets[i]); ? ? ? ? ? ? ? ? ? ? ?// 對每個桶進(jìn)行排序,這里使用了插入排序? ? ? ? for (var j = 0; j < buckets[i].length; j++) {? ? ? ? ? ? arr.push(buckets[i][j]); ? ? ? ? ? ? ? ? ? ? ?? ? ? ? }? ? }? ? return arr;}Java實例 public class BucketSort implements IArraySort {? ? private static final InsertSort insertSort = new InsertSort();? ? @Override? ? public int[] sort(int[] sourceArray) throws Exception {? ? ? ? // 對 arr 進(jìn)行拷貝,不改變參數(shù)內(nèi)容? ? ? ? int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);? ? ? ? return bucketSort(arr, 5);? ? }? ? private int[] bucketSort(int[] arr, int bucketSize) throws Exception {? ? ? ? if (arr.length == 0) {? ? ? ? ? ? return arr;? ? ? ? }? ? ? ? int minValue = arr[0];? ? ? ? int maxValue = arr[0];? ? ? ? for (int value : arr) {? ? ? ? ? ? if (value < minValue) {? ? ? ? ? ? ? ? minValue = value;? ? ? ? ? ? } else if (value > maxValue) {? ? ? ? ? ? ? ? maxValue = value;? ? ? ? ? ? }? ? ? ? }? ? ? ? int bucketCount = (int) Math.floor((maxValue - minValue) / bucketSize) + 1;? ? ? ? int[][] buckets = new int[bucketCount][0];? ? ? ? // 利用映射函數(shù)將數(shù)據(jù)分配到各個桶中? ? ? ? for (int i = 0; i < arr.length; i++) {? ? ? ? ? ? int index = (int) Math.floor((arr[i] - minValue) / bucketSize);? ? ? ? ? ? buckets[index] = arrAppend(buckets[index], arr[i]);? ? ? ? }? ? ? ? int arrIndex = 0;? ? ? ? for (int[] bucket : buckets) {? ? ? ? ? ? if (bucket.length <= 0) {? ? ? ? ? ? ? ? continue;? ? ? ? ? ? }? ? ? ? ? ? // 對每個桶進(jìn)行排序,這里使用了插入排序? ? ? ? ? ? bucket = insertSort.sort(bucket);? ? ? ? ? ? for (int value : bucket) {? ? ? ? ? ? ? ? arr[arrIndex++] = value;? ? ? ? ? ? }? ? ? ? }? ? ? ? return arr;? ? }? ? /**? ? ?* 自動擴容,并保存數(shù)據(jù)? ? ?*? ? ?* @param arr? ? ?* @param value? ? ?*/? ? private int[] arrAppend(int[] arr, int value) {? ? ? ? arr = Arrays.copyOf(arr, arr.length + 1);? ? ? ? arr[arr.length - 1] = value;? ? ? ? return arr;? ? }}PHP實例 function bucketSort($arr, $bucketSize = 5){? ? if (count($arr) === 0) {? ? ? return $arr;? ? }? ? $minValue = $arr[0];? ? $maxValue = $arr[0];? ? for ($i = 1; $i < count($arr); $i++) {? ? ? if ($arr[$i] < $minValue) {? ? ? ? ? $minValue = $arr[$i];? ? ? } else if ($arr[$i] > $maxValue) {? ? ? ? ? $maxValue = $arr[$i];? ? ? }? ? }? ? $bucketCount = floor(($maxValue - $minValue) / $bucketSize) + 1;? ? $buckets = array();? ? for ($i = 0; $i < $bucketCount; $i++) {? ? ? ? $buckets[$i] = [];? ? }? ? for ($i = 0; $i < count($arr); $i++) {? ? ? ? $buckets[floor(($arr[$i] - $minValue) / $bucketSize)][] = $arr[$i];? ? }? ? $arr = array();? ? for ($i = 0; $i < count($buckets); $i++) {? ? ? ? $bucketTmp = $buckets[$i];? ? ? ? sort($bucketTmp);? ? ? ? for ($j = 0; $j < count($bucketTmp); $j++) {? ? ? ? ? ? $arr[] = $bucketTmp[$j];? ? ? ? }? ? }? ? return $arr;}C++實例 #include#include#includeusing namespace std;const int BUCKET_NUM = 10;struct ListNode{? ? ? ? explicit ListNode(int i=0):mData(i),mNext(NULL){}? ? ? ? ListNode* mNext;? ? ? ? int mData;};ListNode* insert(ListNode* head,int val){? ? ? ? ListNode dummyNode;? ? ? ? ListNode *newNode = new ListNode(val);? ? ? ? ListNode *pre,*curr;? ? ? ? dummyNode.mNext = head;? ? ? ? pre = &dummyNode;? ? ? ? curr = head;? ? ? ? while(NULL!=curr && curr->mData<=val){? ? ? ? ? ? ? ? pre = curr;? ? ? ? ? ? ? ? curr = curr->mNext;? ? ? ? }? ? ? ? newNode->mNext = curr;? ? ? ? pre->mNext = newNode;? ? ? ? return dummyNode.mNext;}ListNode* Merge(ListNode *head1,ListNode *head2){? ? ? ? ListNode dummyNode;? ? ? ? ListNode *dummy = &dummyNode;? ? ? ? while(NULL!=head1 && NULL!=head2){? ? ? ? ? ? ? ? if(head1->mData <= head2->mData){? ? ? ? ? ? ? ? ? ? ? ? dummy->mNext = head1;? ? ? ? ? ? ? ? ? ? ? ? head1 = head1->mNext;? ? ? ? ? ? ? ? }else{? ? ? ? ? ? ? ? ? ? ? ? dummy->mNext = head2;? ? ? ? ? ? ? ? ? ? ? ? head2 = head2->mNext;? ? ? ? ? ? ? ? }? ? ? ? ? ? ? ? dummy = dummy->mNext;? ? ? ? }? ? ? ? if(NULL!=head1) dummy->mNext = head1;? ? ? ? if(NULL!=head2) dummy->mNext = head2;? ? ? ? ? ? ? ? return dummyNode.mNext;}void BucketSort(int n,int arr[]){? ? ? ? vector buckets(BUCKET_NUM,(ListNode*)(0));? ? ? ? for(int i=0;imData;? ? ? ? ? ? ? ? head = head->mNext;? ? ? ? }}

參考地址:

https://github.com/hustcc/JS-Sorting-Algorithm/blob/master/9.bucketSort.md

https://zh.wikipedia.org/wiki/%E6%A1%B6%E6%8E%92%E5%BA%8F

以下是熱心網(wǎng)友對桶排序算法的補充,僅供參考:

熱心網(wǎng)友提供的補充1:

# coding=utf-8
# author: [email protected]
# datetime:2020/7/28 18:37

"""
程序說明:
    桶排序
    1)在額外空間充足的情況下,盡量增大桶的數(shù)量
    2)使用的映射函數(shù)能夠?qū)⑤斎氲?N 個數(shù)據(jù)均勻的分配到 K 個桶中
      個人理解,如果都是整數(shù)還可以用計數(shù)排序來計數(shù)統(tǒng)計然后排序,但是如果是一個連續(xù)空間內(nèi)的排序,即統(tǒng)計的是一個浮點類型的數(shù)組成
      的數(shù)組,那么,就無法開辟一個對應(yīng)的空間使其一一對應(yīng)的存儲。此時,我們需要新建一個帶有存儲范圍的空間,來存儲一定范圍內(nèi)的元素
    空間復(fù)雜度:O(n)
    時間復(fù)雜度: O(n)
    穩(wěn)定
"""


def bucket_sort_simplify(arr, max_num):
    """
    簡化版
    """
    buf = {i: [] for i in range(int(max_num)+1)}  # 不能使用[[]]*(max+1),這樣新建的空間中各個[]是共享內(nèi)存的
    arr_len = len(arr)
    for i in range(arr_len):
        num = arr[i]
        buf[int(num)].append(num)  # 將相應(yīng)范圍內(nèi)的數(shù)據(jù)加入到[]中
    arr = []
    for i in range(len(buf)):
        if buf[i]:
            arr.extend(sorted(buf[i]))  # 這里還需要對一個范圍內(nèi)的數(shù)據(jù)進(jìn)行排序,然后再進(jìn)行輸出
    return arr


if __name__ == "__main__":
    lis = [3.1, 4.2, 3.3, 3.5, 2.2, 2.7, 2.9, 2.1, 1.55, 4.456, 6.12, 5.2, 5.33, 6.0, 2.12]
    print(bucket_sort_simplify(lis, max(lis)))

熱心網(wǎng)友提供的補充2:

又沒把C#的寫進(jìn)來,我來寫掉吧,代碼如下:

static void BucketSort(List list, int bucketCount, int maxBucketCount)
{
    List> buckets = new List>(bucketCount);//二維列表
    for (int i = 0; i < bucketCount; i++)
    {
        buckets.Add(new List());
    }
    for (int i = 0; i < list.Count; i++)
    {
        // int j = Mathf.Min(list[i] / (maxBucketCount / bucketCount), bucketCount - 1);//j表示改放的哪個桶,不能大于n-1
        int j = Math.Min(list[i] / (maxBucketCount / bucketCount), bucketCount - 1);//j表示改放的哪個桶,不能大于n-1
        buckets[j].Add(list[i]);//放入對應(yīng)桶
        for (int x = buckets[j].Count - 1; x > 0; x--)//放一個排序一次,兩兩對比就可以
        {
            if (buckets[j][x] < buckets[j][x - 1])//升序
            {
                int tmp = buckets[j][x];//交換
                buckets[j][x] = buckets[j][x - 1];
                buckets[j][x - 1] = tmp;
            }
            else
            {
                break;//如果不發(fā)生交換直接退出,因為前面的之前就排序好了
            }
        }
    }
    list.Clear();//輸出
    for (int i = 0; i < buckets.Count; i++)
    {
        list.AddRange(buckets[i]);
    }
}

熱心網(wǎng)友提供的補充3:

C 語言實現(xiàn)桶排序,桶內(nèi)采用插入排序:

#include 
#include 
#include 


#define BUCKET_SIZE (5) /**< 假定均勻分布的情況下平均每個桶放幾個元素*/


typedef struct Node
{
    int elem;
    struct Node* list_next;
} Node;

typedef struct BucketManager
{
    int nums;
    Node** buckets;  
} BucketManager;

typedef struct BucketSpaceManager
{
    int index;
    Node* nodes_space;
} BucketSpaceManager;


BucketSpaceManager* init_bucket_space(int size)
{
    BucketSpaceManager* space_mgr = (BucketSpaceManager*)malloc(sizeof(BucketSpaceManager));
    if (!space_mgr)
    {
        printf("out of memory,File:%s, Func:%s, Line:%d
", __FILE__, __func__, __LINE__);
        goto exit_1;
    }
    space_mgr->index = 0;
    space_mgr->nodes_space = (Node*)malloc(size * sizeof(Node));
    if (!space_mgr->nodes_space)
    {
        printf("out of memory,File:%s, Func:%s, Line:%d
", __FILE__, __func__, __LINE__);
        goto exit_2;
    }

    return space_mgr;

exit_2:
    free(space_mgr);
exit_1:
    return NULL;
}


BucketManager* init_buckets(int bucket_nums)
{
    BucketManager* bucket_mgr = (BucketManager*)malloc(sizeof(BucketManager));
    if (!bucket_mgr)
    {
        printf("out of memory,File:%s, Func:%s, Line:%d
", __FILE__, __func__, __LINE__);
        goto exit_1;
    }
    bucket_mgr->nums = bucket_nums;
    bucket_mgr->buckets = (Node**)calloc(bucket_mgr->nums, sizeof(Node*));
    if (!bucket_mgr->buckets)
    {
        printf("out of memory,File:%s, Func:%s, Line:%d
", __FILE__, __func__, __LINE__);
        goto exit_2;
    }
    return bucket_mgr;
exit_2:
    free(bucket_mgr);
exit_1:
    return NULL;
}


Node* get_bucket_space(BucketSpaceManager* space_mgr)
{
    if (space_mgr)
    {
        return &space_mgr->nodes_space[space_mgr->index++];
    }
    else
    {
        return NULL;
    }
}


void release_bucket_space(BucketSpaceManager* space_mgr)
{
    if (space_mgr)
    {
        if (space_mgr->nodes_space)
        {
            free(space_mgr->nodes_space);
        }
        free(space_mgr);
    }
}


void release_buckets(BucketManager* buckets_mgr)
{
    if (buckets_mgr)
    {
        if (buckets_mgr->buckets)
        {
            free(buckets_mgr->buckets);
        }
        free(buckets_mgr);
    }
}

int find_max_min(int* arr, int size, int* p_max, int* p_min)
{
    if (size <= 0)
    {
        return -1;
    }
    *p_max = arr[0];
    *p_min = arr[0];
    int i;
    for (i = 1; i < size; ++i)
    {
        if (arr[i] > *p_max)
        {
            *p_max = arr[i];
        }
        if (arr[i] < *p_min)
        {
            *p_min = arr[i];
        }
    }
    return 0;
}


int insert_bucket(BucketManager* bucket_mgr, int index, Node* new_node)
{
    Node* cur, *pre;
    if (!bucket_mgr->buckets[index])
    {
        bucket_mgr->buckets[index] = new_node;
    }
    else
    {
        /** 桶內(nèi)使用插入排序 */
        cur = bucket_mgr->buckets[index];
        pre = cur;
        while (cur->list_next && new_node->elem > cur->elem)
        {
            pre = cur;
            cur = cur->list_next;
        }

        if (new_node->elem <= cur->elem)
        {
            if (pre == cur)
            {
                new_node->list_next = cur;
                bucket_mgr->buckets[index] = new_node;
            }
            else
            {
                new_node->list_next = cur;
                pre->list_next = new_node;
            }
        }
        else
        {
            cur->list_next = new_node;
        }

    }
    return 0;
}


void bucket_sort(int* arr, int size)
{
    int max, min;
    int ret = find_max_min(arr, size, &max, &min);
    if (ret < 0)
    {
        return;
    }

    BucketSpaceManager* space_mgr = init_bucket_space(size);
    if (!space_mgr)
    {
        printf("out of memory,File:%s, Func:%s, Line:%d
", __FILE__, __func__, __LINE__);
        goto exit_1;
    }

    int bucket_nums = (max - min) / BUCKET_SIZE + 1;
    BucketManager* bucket_mgr = init_buckets(bucket_nums);
    if (!bucket_mgr)
    {
        goto exit_2;
    }
    int i;
    for (i = 0; i < size; ++i)
    {
        int index = (arr[i] - min) / BUCKET_SIZE;
        Node* new_node = get_bucket_space(space_mgr);
        if (!new_node)
        {
            goto exit_3;
        }
        new_node->elem = arr[i];
        new_node->list_next = NULL;
        insert_bucket(bucket_mgr, index, new_node);
    }
    for (i = 0; i < bucket_mgr->nums; ++i)
    {
        Node* node = bucket_mgr->buckets[i];
        while(node)
        {
            printf("%d ", node->elem);
            node = node->list_next;
        }
    }
    printf("
");
exit_3:
    release_buckets(bucket_mgr);
exit_2:
    release_bucket_space(space_mgr);
exit_1:
    return;
}

下載測試代碼

以上為桶排序算法詳細(xì)介紹,插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數(shù)排序等排序算法各有優(yōu)缺點,用一張圖概括:

關(guān)于時間復(fù)雜度

平方階 (O(n2)) 排序 各類簡單排序:直接插入、直接選擇和冒泡排序。

線性對數(shù)階 (O(nlog2n)) 排序 快速排序、堆排序和歸并排序;

O(n1+§)) 排序,§ 是介于 0 和 1 之間的常數(shù)。 希爾排序

線性階 (O(n)) 排序 基數(shù)排序,此外還有桶、箱排序。

關(guān)于穩(wěn)定性

穩(wěn)定的排序算法:冒泡排序、插入排序、歸并排序和基數(shù)排序。

不是穩(wěn)定的排序算法:選擇排序、快速排序、希爾排序、堆排序。

名詞解釋:

n:數(shù)據(jù)規(guī)模

k:"桶"的個數(shù)

In-place:占用常數(shù)內(nèi)存,不占用額外內(nèi)存

Out-place:占用額外內(nèi)存

穩(wěn)定性:排序后 2 個相等鍵值的順序和排序之前它們的順序相同

文檔

桶排序

桶排序是計數(shù)排序的升級版。它利用了函數(shù)的映射關(guān)系,高效與否的關(guān)鍵就在于這個映射函數(shù)的確定。
推薦度:
為你推薦
資訊專欄
熱門視頻
相關(guān)推薦
如何按照計數(shù)進(jìn)行排序 描寫元宵節(jié)的唯美詩詞 堆排序怎么排 關(guān)于蘭花的詩句兩句 java快速排序 關(guān)于寫小動物的詩 描寫夏天的詩句簡單 踏青詩句最出名詩句 描寫燕子的古詩絕句 歸并排序python 希爾排序 選擇排序法 基數(shù)排序怎么排 冒泡排序python 關(guān)于放風(fēng)箏的古詩 桶式排序 計數(shù)排序算法c++實現(xiàn) 堆排序法排序怎么排 關(guān)于蘭花的詩句古詩 快速排序c語言 寫與風(fēng)箏有關(guān)的詩 冒泡排序python代碼 基數(shù)排序 選擇排序 插入排序 java希爾排序算法 歸并排序c語言 積累描寫燕子的詩句 出門踏青的詩句 5首夏天的古詩簡單 描寫小動物的古詩 快速排序java 蘭花的詩詞佳句 元宵節(jié)代表詩詞 托爾斯泰的名言 列寧的名言 關(guān)于樂觀的名言 有關(guān)友誼的名言 關(guān)于交友的名言警句 關(guān)于家的名言
Top 亚洲国产第一站精品蜜芽_亚洲AV无码精品色午夜果冻不卡_国产香蕉九九久久精品免费_国产精品亚洲专区无码不卡
<sup id="m40ya"></sup>
  • 
    
  • <kbd id="m40ya"></kbd>
    <samp id="m40ya"></samp>
    <ul id="m40ya"></ul>
  • 久久免费午夜影院| 狠狠色综合色区| 欧美在线视频一区二区| 亚洲精品国产日韩| 国内精品久久久久影院优| 欧美日韩国产首页| 蜜臀久久99精品久久久画质超高清| 亚洲一品av免费观看| 亚洲精品偷拍| 亚洲国产专区校园欧美| 国内成人在线| 国产亚洲精品综合一区91| 国产精品久久久一区二区| 欧美日韩性视频在线| 男人的天堂成人在线| 久久视频精品在线| 久久精品在线视频| 久久久久久色| 久久精品中文| 久久久一二三| 久久综合国产精品| 久久综合国产精品台湾中文娱乐网| 欧美一区二区日韩一区二区| 午夜亚洲影视| 久久久久一区二区三区| 久久一二三区| 欧美国产日韩一区| 欧美日韩国产91| 欧美日韩一区二区在线视频 | 欧美va亚洲va日韩∨a综合色| 久久www成人_看片免费不卡| 欧美在线视频一区二区| 久久久久se| 欧美黄色小视频| 欧美日韩另类一区| 国产精品你懂的在线欣赏| 国产视频欧美| 一区视频在线播放| 亚洲精品免费在线| 亚洲主播在线| 久久久五月天| 欧美日韩精品系列| 国产日本精品| 亚洲高清免费| 在线视频欧美一区| 久久精品中文| 欧美日本中文字幕| 国产视频一区在线观看| 91久久国产综合久久蜜月精品| 亚洲最新中文字幕| 久久精品日韩| 欧美日韩妖精视频| 激情成人中文字幕| 亚洲视频一区二区| 久久先锋资源| 国产精品丝袜白浆摸在线| 亚洲国产精品www| 亚洲欧美一区二区三区久久| 欧美成人在线影院| 国产精品自拍三区| 日韩亚洲欧美成人一区| 国产视频在线一区二区| 日韩视频在线一区二区| 久久久久国产精品www| 欧美午夜免费电影| 亚洲精品久久久久久下一站| 午夜精品久久久久久久白皮肤 | 国产日韩欧美a| 日韩一区二区免费高清| 久久天天躁狠狠躁夜夜av| 国产精品欧美经典| 一本综合精品| 欧美激情综合色| 亚洲第一综合天堂另类专| 欧美亚洲一区| 国产精品欧美在线| 一区二区三区日韩欧美精品| 欧美成人自拍| 91久久久久久久久| 毛片精品免费在线观看| 狠狠色综合网站久久久久久久| 亚洲欧美日韩精品久久| 国产精品成人免费视频| 亚洲人久久久| 麻豆av一区二区三区| 欧美精品色综合| 国外成人性视频| 午夜精品影院| 欧美激情视频免费观看| 伊人久久成人| 一本久久综合亚洲鲁鲁| 免费欧美日韩国产三级电影| 国产一区二区中文字幕免费看| 欧美有码在线视频| 国产一区二区激情| 久久久久久精| 亚洲第一在线综合在线| 欧美电影专区| 亚洲美女尤物影院| 欧美午夜电影完整版| 亚洲男人影院| 国产日韩在线亚洲字幕中文| 久久精品99| 亚洲高清一区二| 欧美日韩系列| 亚洲欧美日韩人成在线播放| 国产日韩欧美在线播放不卡| 久久免费国产精品1| 亚洲激情av| 国产精品老牛| 久久九九国产| 亚洲日本aⅴ片在线观看香蕉| 欧美日韩一区二| 欧美一区二区私人影院日本| 在线观看日韩精品| 欧美日韩国产三区| 久久国产精品亚洲va麻豆| 亚洲国产mv| 国产精品亚洲激情| 美女网站在线免费欧美精品| 在线视频欧美日韩| 国语自产精品视频在线看| 欧美国产日韩一二三区| 欧美亚洲综合网| 日韩一级网站| 狠狠色丁香久久综合频道| 欧美日韩国产系列| 久久久久久综合| 亚洲午夜一区二区| 亚洲电影在线播放| 国产精品xxxav免费视频| 乱人伦精品视频在线观看| 亚洲午夜精品视频| 亚洲国产欧美日韩| 国产欧美视频一区二区| 欧美精品www在线观看| 极品中文字幕一区| 欧美日韩午夜在线视频| 久久福利视频导航| 亚洲午夜精品久久| 亚洲第一区在线| 国产欧美一区二区色老头| 欧美看片网站| 老司机67194精品线观看| 亚洲免费在线视频一区 二区| 亚洲欧洲在线播放| 黄色精品一区二区| 国产女主播一区二区| 欧美性猛交xxxx乱大交蜜桃 | 国产精品日日摸夜夜添夜夜av| 欧美+日本+国产+在线a∨观看| 欧美一区日韩一区| 亚洲欧美另类国产| 亚洲色在线视频| 野花国产精品入口| 日韩午夜av| 99国产精品久久久久久久成人热| 在线精品高清中文字幕| 国内久久婷婷综合| 韩国av一区二区| 国精品一区二区| 国语自产在线不卡| 国产日韩欧美三区| 国产性天天综合网| 国模私拍一区二区三区| 国产一区91精品张津瑜| 国产一区二区三区高清在线观看| 欧美日韩精品欧美日韩精品| 免费日韩精品中文字幕视频在线| 久久久久国产一区二区三区| 久久青草久久| 免费在线成人| 欧美激情一区二区久久久| 欧美激情1区2区3区| 欧美日本精品在线| 欧美成年人视频网站| 欧美激情综合五月色丁香| 欧美日韩国产一级| 国产精品久久久久久久久久久久久 | 亚洲欧洲精品一区二区三区不卡 | 欧美激情在线免费观看| 欧美久久电影| 国产精品久久久久久久久借妻| 国产精品一区二区三区免费观看 | 久久激情视频免费观看| 蜜桃久久精品乱码一区二区| 欧美激情按摩| 国产精品扒开腿做爽爽爽视频| 国产精品腿扒开做爽爽爽挤奶网站| 国产欧美日韩一区二区三区在线观看| 国产自产v一区二区三区c| 亚洲黄色成人久久久| 亚洲视频第一页| 久久精品2019中文字幕| 欧美高清视频一二三区| 国产精品人人做人人爽| 在线成人av.com| 亚洲欧美福利一区二区| 欧美成人乱码一区二区三区| 国产精品免费观看视频|