69堂国产成人免费视频_亚洲成人999_最新日韩中文字幕_97在线视频免费_91久久国产精品_欧美美女一区二区_亚洲a级在线观看_亚洲最大成人免费视频_av中文字幕不卡_一本色道久久综合亚洲精品按摩

更多精彩內容,歡迎關注:

視頻號
視頻號

抖音
抖音

快手
快手

微博
微博

用c語言實現堆排序算法

文檔

用c語言實現堆排序算法

堆排序(Heapsort)是指利用堆這種數據結構所設計的一種排序算法。堆積是一個近似完全二叉樹的結構,并同時滿足堆積的性質:即子結點的鍵值或索引總是小于(或者大于)它的父節點。堆排序可以說是一種利用堆的概念來排序的選擇排序。
推薦度:
導讀堆排序(Heapsort)是指利用堆這種數據結構所設計的一種排序算法。堆積是一個近似完全二叉樹的結構,并同時滿足堆積的性質:即子結點的鍵值或索引總是小于(或者大于)它的父節點。堆排序可以說是一種利用堆的概念來排序的選擇排序。
.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}

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

堆排序(Heapsort)是指利用堆這種數據結構所設計的一種排序算法。堆積是一個近似完全二叉樹的結構,并同時滿足堆積的性質:即子結點的鍵值或索引總是小于(或者大于)它的父節點。堆排序可以說是一種利用堆的概念來排序的選擇排序。分為兩種方法:

大頂堆:每個節點的值都大于或等于其子節點的值,在堆排序算法中用于升序排列;小頂堆:每個節點的值都小于或等于其子節點的值,在堆排序算法中用于降序排列;

堆排序的平均時間復雜度為 Ο(nlogn)。

1. 算法步驟

創建一個堆 H[0……n-1];

把堆首(最大值)和堆尾互換;

把堆的尺寸縮小 1,并調用 shift_down(0),目的是把新的數組頂端數據調整到相應位置;

重復步驟 2,直到堆的尺寸為 1。

2. 動圖演示

代碼實現JavaScript 實例 var len; ? ?// 因為聲明的多個函數都需要數據長度,所以把len設置成為全局變量function buildMaxHeap(arr) { ? // 建立大頂堆? ? len = arr.length;? ? for (var i = Math.floor(len/2); i >= 0; i--) {? ? ? ? heapify(arr, i);? ? }}function heapify(arr, i) { ? ? // 堆調整? ? var left = 2 * i + 1,? ? ? ? right = 2 * i + 2,? ? ? ? largest = i;? ? if (left < len && arr[left] > arr[largest]) {? ? ? ? largest = left;? ? }? ? if (right < len && arr[right] > arr[largest]) {? ? ? ? largest = right;? ? }? ? if (largest != i) {? ? ? ? swap(arr, i, largest);? ? ? ? heapify(arr, largest);? ? }}function swap(arr, i, j) {? ? var temp = arr[i];? ? arr[i] = arr[j];? ? arr[j] = temp;}function heapSort(arr) {? ? buildMaxHeap(arr);? ? for (var i = arr.length-1; i > 0; i--) {? ? ? ? swap(arr, 0, i);? ? ? ? len--;? ? ? ? heapify(arr, 0);? ? }? ? return arr;}Python實例 def buildMaxHeap(arr):? ? import math? ? for i in range(math.floor(len(arr)/2),-1,-1):? ? ? ? heapify(arr,i)def heapify(arr, i):? ? left = 2*i+1? ? right = 2*i+2? ? largest = i? ? if left < arrLen and arr[left] > arr[largest]:? ? ? ? largest = left? ? if right < arrLen and arr[right] > arr[largest]:? ? ? ? largest = right? ? if largest != i:? ? ? ? swap(arr, i, largest)? ? ? ? heapify(arr, largest)def swap(arr, i, j):? ? arr[i], arr[j] = arr[j], arr[i]def heapSort(arr):? ? global arrLen? ? arrLen = len(arr)? ? buildMaxHeap(arr)? ? for i in range(len(arr)-1,0,-1):? ? ? ? swap(arr,0,i)? ? ? ? arrLen -=1? ? ? ? heapify(arr, 0)? ? return arrGo實例 func heapSort(arr []int) []int {? ? ? ? arrLen := len(arr)? ? ? ? buildMaxHeap(arr, arrLen)? ? ? ? for i := arrLen - 1; i >= 0; i-- {? ? ? ? ? ? ? ? swap(arr, 0, i)? ? ? ? ? ? ? ? arrLen -= 1? ? ? ? ? ? ? ? heapify(arr, 0, arrLen)? ? ? ? }? ? ? ? return arr}func buildMaxHeap(arr []int, arrLen int) {? ? ? ? for i := arrLen / 2; i >= 0; i-- {? ? ? ? ? ? ? ? heapify(arr, i, arrLen)? ? ? ? }}func heapify(arr []int, i, arrLen int) {? ? ? ? left := 2*i + 1? ? ? ? right := 2*i + 2? ? ? ? largest := i? ? ? ? if left < arrLen && arr[left] > arr[largest] {? ? ? ? ? ? ? ? largest = left? ? ? ? }? ? ? ? if right < arrLen && arr[right] > arr[largest] {? ? ? ? ? ? ? ? largest = right? ? ? ? }? ? ? ? if largest != i {? ? ? ? ? ? ? ? swap(arr, i, largest)? ? ? ? ? ? ? ? heapify(arr, largest, arrLen)? ? ? ? }}func swap(arr []int, i, j int) {? ? ? ? arr[i], arr[j] = arr[j], arr[i]}Java實例 public class HeapSort implements IArraySort {? ? @Override? ? public int[] sort(int[] sourceArray) throws Exception {? ? ? ? // 對 arr 進行拷貝,不改變參數內容? ? ? ? int[] arr = Arrays.copyOf(sourceArray, sourceArray.length);? ? ? ? int len = arr.length;? ? ? ? buildMaxHeap(arr, len);? ? ? ? for (int i = len - 1; i > 0; i--) {? ? ? ? ? ? swap(arr, 0, i);? ? ? ? ? ? len--;? ? ? ? ? ? heapify(arr, 0, len);? ? ? ? }? ? ? ? return arr;? ? }? ? private void buildMaxHeap(int[] arr, int len) {? ? ? ? for (int i = (int) Math.floor(len / 2); i >= 0; i--) {? ? ? ? ? ? heapify(arr, i, len);? ? ? ? }? ? }? ? private void heapify(int[] arr, int i, int len) {? ? ? ? int left = 2 * i + 1;? ? ? ? int right = 2 * i + 2;? ? ? ? int largest = i;? ? ? ? if (left < len && arr[left] > arr[largest]) {? ? ? ? ? ? largest = left;? ? ? ? }? ? ? ? if (right < len && arr[right] > arr[largest]) {? ? ? ? ? ? largest = right;? ? ? ? }? ? ? ? if (largest != i) {? ? ? ? ? ? swap(arr, i, largest);? ? ? ? ? ? heapify(arr, largest, len);? ? ? ? }? ? }? ? private void swap(int[] arr, int i, int j) {? ? ? ? int temp = arr[i];? ? ? ? arr[i] = arr[j];? ? ? ? arr[j] = temp;? ? }}PHP 實例 function buildMaxHeap(&$arr){? ? global $len;? ? for ($i = floor($len/2); $i >= 0; $i--) {? ? ? ? heapify($arr, $i);? ? }}function heapify(&$arr, $i){? ? global $len;? ? $left = 2 * $i + 1;? ? $right = 2 * $i + 2;? ? $largest = $i;? ? if ($left < $len && $arr[$left] > $arr[$largest]) {? ? ? ? $largest = $left;? ? }? ? if ($right < $len && $arr[$right] > $arr[$largest]) {? ? ? ? $largest = $right;? ? }? ? if ($largest != $i) {? ? ? ? swap($arr, $i, $largest);? ? ? ? heapify($arr, $largest);? ? }}function swap(&$arr, $i, $j){? ? $temp = $arr[$i];? ? $arr[$i] = $arr[$j];? ? $arr[$j] = $temp;}function heapSort($arr) {? ? global $len;? ? $len = count($arr);? ? buildMaxHeap($arr);? ? for ($i = count($arr) - 1; $i > 0; $i--) {? ? ? ? swap($arr, 0, $i);? ? ? ? $len--;? ? ? ? heapify($arr, 0);? ? }? ? return $arr;}C實例 #include #include void swap(int *a, int *b) {? ? int temp = *b;? ? *b = *a;? ? *a = temp;}void max_heapify(int arr[], int start, int end) {? ? // 建立父節點指標和子節點指標? ? int dad = start;? ? int son = dad * 2 + 1;? ? while (son <= end) { // 若子節點指標在範圍內才做比較? ? ? ? if (son + 1 <= end && arr[son] < arr[son + 1]) // 先比較兩個子節點大小,選擇最大的? ? ? ? ? ? son++;? ? ? ? if (arr[dad] > arr[son]) //如果父節點大於子節點代表調整完畢,直接跳出函數? ? ? ? ? ? return;? ? ? ? else { // 否則交換父子內容再繼續子節點和孫節點比較? ? ? ? ? ? swap(&arr[dad], &arr[son]);? ? ? ? ? ? dad = son;? ? ? ? ? ? son = dad * 2 + 1;? ? ? ? }? ? }}void heap_sort(int arr[], int len) {? ? int i;? ? // 初始化,i從最後一個父節點開始調整? ? for (i = len / 2 - 1; i >= 0; i--)? ? ? ? max_heapify(arr, i, len - 1);? ? // 先將第一個元素和已排好元素前一位做交換,再重新調整,直到排序完畢? ? for (i = len - 1; i > 0; i--) {? ? ? ? swap(&arr[0], &arr[i]);? ? ? ? max_heapify(arr, 0, i - 1);? ? }}int main() {? ? int arr[] = { 3, 5, 3, 0, 8, 6, 1, 5, 8, 6, 2, 4, 9, 4, 7, 0, 1, 8, 9, 7, 3, 1, 2, 5, 9, 7, 4, 0, 2, 6 };? ? int len = (int) sizeof(arr) / sizeof(*arr);? ? heap_sort(arr, len);? ? int i;? ? for (i = 0; i < len; i++)? ? ? ? printf("%d ", arr[i]);? ? printf(" ");? ? return 0;}C++實例 #include #include using namespace std;void max_heapify(int arr[], int start, int end) {? ? // 建立父節點指標和子節點指標? ? int dad = start;? ? int son = dad * 2 + 1;? ? while (son <= end) { // 若子節點指標在範圍內才做比較? ? ? ? if (son + 1 <= end && arr[son] < arr[son + 1]) // 先比較兩個子節點大小,選擇最大的? ? ? ? ? ? son++;? ? ? ? if (arr[dad] > arr[son]) // 如果父節點大於子節點代表調整完畢,直接跳出函數? ? ? ? ? ? return;? ? ? ? else { // 否則交換父子內容再繼續子節點和孫節點比較? ? ? ? ? ? swap(arr[dad], arr[son]);? ? ? ? ? ? dad = son;? ? ? ? ? ? son = dad * 2 + 1;? ? ? ? }? ? }}void heap_sort(int arr[], int len) {? ? // 初始化,i從最後一個父節點開始調整? ? for (int i = len / 2 - 1; i >= 0; i--)? ? ? ? max_heapify(arr, i, len - 1);? ? // 先將第一個元素和已經排好的元素前一位做交換,再從新調整(剛調整的元素之前的元素),直到排序完畢? ? for (int i = len - 1; i > 0; i--) {? ? ? ? swap(arr[0], arr[i]);? ? ? ? max_heapify(arr, 0, i - 1);? ? }}int main() {? ? int arr[] = { 3, 5, 3, 0, 8, 6, 1, 5, 8, 6, 2, 4, 9, 4, 7, 0, 1, 8, 9, 7, 3, 1, 2, 5, 9, 7, 4, 0, 2, 6 };? ? int len = (int) sizeof(arr) / sizeof(*arr);? ? heap_sort(arr, len);? ? for (int i = 0; i < len; i++)? ? ? ? cout << arr[i] << ' ';? ? cout << endl;? ? return 0;}

參考文章:

https://github.com/hustcc/JS-Sorting-Algorithm/blob/master/7.heapSort.md

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

以下是熱心網友對堆排序算法的補充,僅供參考:

熱心網友提供的補充1:

上方又沒些 C# 的堆排序,艾孜爾江補充如下:

/// 
/// 堆排序
/// 
/// 待排序數組
static void HeapSort(int[] arr)
{
    int vCount = arr.Length;
    int[] tempKey = new int[vCount + 1];
    // 元素索引從1開始
    for (int i = 0; i < vCount; i++)
    {
        tempKey[i + 1] = arr[i];
    }
    // 初始數據建堆(從含最后一個結點的子樹開始構建,依次向前,形成整個二叉堆)
    for (int i = vCount / 2; i >= 1; i--)
    {
        Restore(tempKey, i, vCount);
    }
    // 不斷輸出堆頂元素、重構堆,進行排序
    for (int i = vCount; i > 1; i--)
    {
        int temp = tempKey[i];
        tempKey[i] = tempKey[1];
        tempKey[1] = temp;
        Restore(tempKey, 1, i - 1);
    }
    //排序結果
    for (int i = 0; i < vCount; i++)
    {
        arr[i] = tempKey[i + 1];
    }
}
/// 
/// 二叉堆的重構(針對于已構建好的二叉堆首尾互換之后的重構)
/// 
/// 
/// 根結點j
/// 結點數
static void Restore(int[] arr, int rootNode, int nodeCount)
{
    while (rootNode <= nodeCount / 2) // 保證根結點有子樹
    {
        //找出左右兒子的最大值
        int m = (2 * rootNode + 1 <= nodeCount && arr[2 * rootNode + 1] > arr[2 * rootNode]) ? 2 * rootNode + 1 : 2 * rootNode;
        if (arr[m] > arr[rootNode])
        {
            int temp = arr[m];
            arr[m] = arr[rootNode];
            arr[rootNode] = temp;
            rootNode = m;
        }
        else
        {
            break;
        }
    }
}

熱心網友提供的補充2:

堆排序是不穩定的排序!

既然如此,每次構建大頂堆時,在 父節點、左子節點、右子節點取三者中最大者作為父節點就行。我們追尋的只是最終排序后的結果,所以可以簡化其中的步驟。

我將個人寫的 Java 代碼核心放在下方,有興趣的同學可以一起討論下:

public int[] sort(int a[]) {
    int len = a.length - 1;    
    for (int i = len; i > 0; i--) {
        maxHeap(a, i);        
        //交換 跟節點root 與 最后一個子節點i 的位置        
        swap(a, 0, i);        
        //i--無序數組尺寸減少了 
    }  
    return a;
}

/**構建一個大頂堆(完全二叉樹 ) 
* 從  最后一個非葉子節點  開始,若父節點小于子節點,則互換他們兩的位置。然后依次從右至左,從下到上進行! 
* 最后一個非葉子節點,它的葉子節點 必定包括了最后一個(葉子)節點,所以 最后一個非葉子節點是 a[(n+1)/2-1] 
 
* @param a 
* @param lastIndex 這個數組的最后一個元素 
*/
static void maxHeap(int a[], int lastIndex) {
    for (int i = (lastIndex + 1) / 2 - 1; i >= 0; i--) {
       //反正 堆排序不穩定,先比較父與左子,大則交換;與右子同理。(不care 左子與右子位置是否變了!) 
        if (i * 2 + 1 <= lastIndex && a[i] < a[i * 2 + 1]) {
            swap(a, i, i * 2 + 1);        
        }    
        if (i * 2 + 2 <= lastIndex && a[i] < a[i * 2 + 2]) {
            swap(a, i, i * 2 + 2);        
        }
    }
}

private void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}
以上為堆排序算法詳細介紹,插入排序、希爾排序、選擇排序、冒泡排序、歸并排序、快速排序、堆排序、基數排序等排序算法各有優缺點,用一張圖概括:

關于時間復雜度

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

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

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

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

關于穩定性

穩定的排序算法:冒泡排序、插入排序、歸并排序和基數排序。

不是穩定的排序算法:選擇排序、快速排序、希爾排序、堆排序。

名詞解釋:

n:數據規模

k:"桶"的個數

In-place:占用常數內存,不占用額外內存

Out-place:占用額外內存

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

文檔

用c語言實現堆排序算法

堆排序(Heapsort)是指利用堆這種數據結構所設計的一種排序算法。堆積是一個近似完全二叉樹的結構,并同時滿足堆積的性質:即子結點的鍵值或索引總是小于(或者大于)它的父節點。堆排序可以說是一種利用堆的概念來排序的選擇排序。
推薦度:
為你推薦
資訊專欄
熱門視頻
相關推薦
歸并排序算法穩定嗎 希爾排序算法特點 直接選擇排序時間復雜度 冒泡排序原理 堆排序c語言 歸并排序劃分子表 希爾排序算法思想 c語言選擇法排序10個數 用冒泡排序法求閏年 歸并排序的詳細過程 希爾排序c語言程序 c語言選擇排序算法 c語言冒泡排序10個數 歸并排序代碼 希爾排序法 選擇排序算法流程圖 冒泡排序的原理 歸并排序圖解 希爾排序例子 簡單選擇排序算法圖解 編寫一個冒泡排序算法 選擇排序法原理 希爾排序c語言 歸并排序思路 堆排序c語言代碼 java冒泡排序 選擇排序思想 希爾排序又叫什么名字 歸并排序算法原理 堆排序算法c語言 冒泡排序c語言 選擇排序算法例子 數據結構希爾排序c語言 歸并排序算法流程圖解 堆排序計算 冒泡排序流程圖 排序算法的一般選擇規則 希爾排序c 實現歸并排序利用的算法 堆是一種什么排序方法
Top 69堂国产成人免费视频_亚洲成人999_最新日韩中文字幕_97在线视频免费_91久久国产精品_欧美美女一区二区_亚洲a级在线观看_亚洲最大成人免费视频_av中文字幕不卡_一本色道久久综合亚洲精品按摩
国产日韩精品久久久| 亚洲欧美偷拍另类a∨色屁股| 国内久久精品视频| 激情深爱一区二区| 国产在线精品不卡| 国产.欧美.日韩| 色婷婷综合久久久久中文一区二区 | 国产精品久99| 五月综合激情网| 国产黄色精品网站| 在线精品国精品国产尤物884a| 欧美一级国产精品| 日本一区二区三区久久久久久久久不 | 国产成人在线电影| 91小宝寻花一区二区三区| 欧美日韩免费电影| 欧美国产精品专区| 蜜臀a∨国产成人精品| 成人久久久精品乱码一区二区三区| 色婷婷av久久久久久久| 久久精品夜夜夜夜久久| 丝袜美腿亚洲综合| 色狠狠色噜噜噜综合网| 久久一夜天堂av一区二区三区| 一区二区三区色| 成人av动漫网站| 久久综合久色欧美综合狠狠| 午夜精品久久久久久久蜜桃app| 成人h动漫精品| 精品999在线播放| 蜜桃一区二区三区在线观看| 91成人国产精品| 亚洲六月丁香色婷婷综合久久| 国产成人免费视频网站高清观看视频| 91麻豆精品国产91久久久资源速度| 一区二区三区在线视频观看| a美女胸又www黄视频久久| 久久综合久久久久88| 美日韩黄色大片| 5858s免费视频成人| 亚洲一级二级三级在线免费观看| 色婷婷激情一区二区三区| 樱桃视频在线观看一区| 91蝌蚪porny九色| 综合激情网...| 一本一本大道香蕉久在线精品| 日韩毛片在线免费观看| 99久久婷婷国产综合精品| 亚洲日本在线视频观看| 欧美三级中文字幕| 亚洲国产wwwccc36天堂| 欧美精品欧美精品系列| 久久疯狂做爰流白浆xx| 国产欧美中文在线| jlzzjlzz亚洲女人18| 一区二区三区在线播放| 欧美精品久久99久久在免费线| 日本伊人色综合网| 久久婷婷国产综合精品青草| 国产成人午夜99999| 亚洲免费av观看| 欧美丰满嫩嫩电影| 国产精品综合一区二区三区| 国产精品乱码人人做人人爱| 在线精品国精品国产尤物884a| 日韩精品每日更新| 国产亚洲欧美日韩在线一区| 色狠狠桃花综合| 美女视频黄a大片欧美| 国产日韩精品久久久| 一本色道综合亚洲| 久热成人在线视频| 亚洲欧美综合在线精品| 日韩一区二区三区视频| 91麻豆成人久久精品二区三区| 理论电影国产精品| 一区二区三区色| 亚洲国产高清aⅴ视频| 欧美日韩一区二区三区免费看| 麻豆91免费看| 亚洲午夜av在线| 国产精品美女一区二区在线观看| 欧美日韩成人综合| 99亚偷拍自图区亚洲| 另类小说综合欧美亚洲| 亚洲小少妇裸体bbw| 国产日韩影视精品| 欧美久久久久久久久| 91网上在线视频| 国产精品99久久久久久宅男| 日韩不卡一二三区| 亚洲综合一区二区| 中文字幕在线不卡视频| 欧美国产精品专区| 久久久久久久久岛国免费| 91精品一区二区三区在线观看| 97精品超碰一区二区三区| 国产一区二区在线观看免费| 丝袜美腿亚洲一区二区图片| 亚洲一区二区偷拍精品| 亚洲女人小视频在线观看| 国产精品天天看| 久久精品免视看| 久久久精品国产99久久精品芒果| 日韩一级在线观看| 欧美美女激情18p| 欧美日韩国产在线观看| 欧美性淫爽ww久久久久无| 色久综合一二码| 在线免费观看一区| 在线观看日韩av先锋影音电影院| 成人免费av资源| av在线不卡电影| 99精品热视频| 在线免费一区三区| 欧美日韩国产综合视频在线观看| 欧美日韩国产小视频| 日韩亚洲欧美一区| 久久精品一区八戒影视| 国产精品毛片a∨一区二区三区| 国产网红主播福利一区二区| 国产日产欧美一区| 国产精品天美传媒沈樵| 亚洲女同ⅹxx女同tv| 日韩国产在线观看一区| 精品制服美女丁香| 国产福利一区在线观看| 91视视频在线直接观看在线看网页在线看| 91久久精品国产91性色tv | 天天av天天翘天天综合网色鬼国产| 亚洲成人动漫av| 精品一区二区三区在线观看国产| 国产精品中文字幕日韩精品| 91美女视频网站| 91麻豆精品国产91久久久久久 | 精品少妇一区二区三区免费观看| 国产人成一区二区三区影院| 一区二区三区 在线观看视频| 日韩综合小视频| 成人午夜视频免费看| 在线观看亚洲一区| 久久综合狠狠综合久久综合88| 亚洲女与黑人做爰| 国模无码大尺度一区二区三区| 97久久人人超碰| 久久综合久久鬼色| 日韩在线a电影| 成人性生交大片免费| 欧美群妇大交群的观看方式| 国产精品伦理一区二区| 久久国产精品区| 6080午夜不卡| 一区二区三区美女视频| 丁香天五香天堂综合| 欧美一二三区在线| 亚洲激情一二三区| 9i在线看片成人免费| 久久精品免费在线观看| 奇米精品一区二区三区四区| 欧美在线免费观看亚洲| 亚洲三级小视频| 99国产欧美另类久久久精品| 久久精品网站免费观看| 久久精品国产成人一区二区三区| 色婷婷久久久久swag精品| 国产目拍亚洲精品99久久精品| 国产曰批免费观看久久久| 精品久久久三级丝袜| 美女一区二区久久| 91精品国产aⅴ一区二区| 午夜免费久久看| 欧美在线free| 午夜久久久影院| 欧美日韩视频一区二区| 亚洲激情一二三区| 欧美日韩一区二区在线观看 | 欧美成人aa大片| 免费在线观看一区二区三区| 欧美日韩精品一区二区三区| 五月天激情小说综合| 欧美一区二区福利在线| 国产在线播放一区| 亚洲国产精品国自产拍av| voyeur盗摄精品| 亚洲va韩国va欧美va| 91美女福利视频| 亚洲成人激情av| 日韩欧美国产1| 狠狠色狠狠色综合系列| 国产欧美一区二区精品忘忧草| 成人一区二区三区中文字幕| 中文字幕一区二区三区色视频| 91影视在线播放| 亚洲成av人影院在线观看网| 欧美一级高清大全免费观看| 国产91精品露脸国语对白| 亚洲狠狠丁香婷婷综合久久久| 日韩午夜精品视频| 不卡av免费在线观看| 日韩激情av在线|