精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

各大排序算法的Objective-C實現以及圖形化演示比較

開發 后端 算法
用Objective-C實現幾種基本的排序算法,并把排序的過程圖形化顯示。其實算法還是挺有趣的 ^ ^.

[[176714]]

用Objective-C實現幾種基本的排序算法,并把排序的過程圖形化顯示。其實算法還是挺有趣的 ^ ^.

  • 選擇排序
  • 冒泡排序
  • 插入排序
  • 快速排序

選擇排序

以升序為例。

選擇排序比較好理解,一句話概括就是依次按位置挑選出適合此位置的元素來填充。

  1. 暫定***個元素為最小元素,往后遍歷,逐個與最小元素比較,若發現更小者,與先前的”最小元素”交換位置。達到更新最小元素的目的。
  2. 一趟遍歷完成后,能確保剛剛完成的這一趟遍歷中,最的小元素已經放置在前方了。然后縮小排序范圍,新一趟排序從數組的第二個元素開始。
  3. 在新一輪排序中重復第1、2步驟,直到范圍不能縮小為止,排序完成。

 

各大排序算法的Objective-C實現以及圖形化演示比較
選擇排序

以下方法在NSMutableArray+JXSort.m中實現

 

  1. - (void)jx_selectionSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback {  
  2. if (self.count == 0) {  
  3. return 
  4.  
  5. for (NSInteger i = 0; i < self.count - 1; i ++) { 
  6. for (NSInteger j = i + 1; j < self.count; j ++) {  
  7. if (comparator(self[i], self[j]) == NSOrderedDescending) {  
  8. [self jx_exchangeWithIndexA:i indexB:j didExchange:exchangeCallback];  
  9.  
  10.  
  11.  

冒泡排序

在一趟遍歷中,不斷地對相鄰的兩個元素進行排序,小的在前大的在后,這樣會造成大值不斷沉底的效果,當一趟遍歷完成時,***的元素會被排在后方正確的位置上。

然后縮小排序范圍,即去掉***方位置正確的元素,對前方數組進行新一輪遍歷,重復第1步驟。直到范圍不能縮小為止,排序完成。

 

各大排序算法的Objective-C實現以及圖形化演示比較

冒泡排序

 

 

  1. - (void)jx_bubbleSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback {  
  2. if (self.count == 0) {  
  3. return 
  4.  
  5. for (NSInteger i = self.count - 1; i > 0; i --) {  
  6. for (NSInteger j = 0; j < i; j ++) {  
  7. if (comparator(self[j], self[j + 1]) == NSOrderedDescending) {  
  8. [self jx_exchangeWithIndexA:j indexB:j + 1 didExchange:exchangeCallback];  
  9.  
  10.  
  11.  

插入排序

插入排序是從一個亂序的數組中依次取值,插入到一個已經排好序的數組中。

這看起來好像要兩個數組才能完成,但如果只想在同一個數組內排序,也是可以的。此時需要想象出兩個區域:前方有序區和后方亂序區。

1、分區。開始時前方有序區只有一個元素,就是數組的***個元素。然后把從第二個元素開始直到結尾的數組作為亂序區。

2、從亂序區取***個元素,把它正確插入到前方有序區中。把它與前方無序區的***一個元素比較,亦即與它的前一個元素比較。

  • 如果比前一個元素要大,則不需要交換,這時有序區擴充一格,亂序區往后縮減一格,相當于直接拼在有序區末尾。
  • 如果和前一個元素相等,則繼續和前二元素比較、再和前三元素比較……如果往前遍歷到頭了,發現前方所有元素值都長一個樣的話(囧),那也可以,不需要交換,這時有序區擴充一格,亂序區往后縮減一格,相當于直接拼在有序區末尾。如果比前一個元素大呢?對不起作為有序區不可能出現這種情況。如果比前一個元素小呢,請看下一點。
  • 如果比前一個元素小,則交換它們的位置。交換完后,繼續比較取出元素和它此時的前一個元素,若更小就交換,若相等就比較前一個,直到遍歷完成。至此,把亂序區***個元素正確插入到前方有序區中。

3、往后縮小亂序區范圍,繼續取縮小范圍后的***個元素,重復第2步驟。直到范圍不能縮小為止,排序完成。

 

各大排序算法的Objective-C實現以及圖形化演示比較

插入排序

 

 

  1. - (void)jx_insertionSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback {  
  2. if (self.count == 0) {  
  3. return 
  4.  
  5. for (NSInteger i = 1; i < self.count; i ++) {  
  6. for (NSInteger j = i; j > 0 && comparator(self[j], self[j - 1]) == NSOrderedAscending; j --) {  
  7. [self jx_exchangeWithIndexA:j indexB:j - 1 didExchange:exchangeCallback];  
  8.  
  9.  

快速排序

快排的版本有好幾種,粗略可分為:

  1. 原始的快排。
  2. 為制造適合高效排序環境而事先打亂數組順序的快排。
  3. 為數組內大量重復值而優化的三向切分快排。

這里只討論原始的快排。

關于在快排過程中何時進行交換以及交換誰的問題,我看見兩種不同的思路:

  1. 當左右兩個游標都停止時,交換兩個游標所指向元素。樞軸所在位置暫時不變,直到兩個游標相遇重合,才更新樞軸位置,交換樞軸與游標所指元素。
  2. 當右游標找到一個比樞軸小的元素時,馬上把樞軸交換到游標所在位置,而游標位置的元素則移到樞軸那里。完成一次樞軸更新。然后左游標再去尋找比樞軸大的元素,同理。

第1種思路可以有效降低交換頻率,在游標相遇后再對樞軸進行定位,這步會導致略微增加了比較的次數;

第2種思路交換操作會比較頻繁,但是在交換的過程中同時也把樞軸的位置不斷進行更新,當游標相遇時,樞軸的定位也完成了。

在兩種思路都嘗試實現過后,我還是喜歡第2種,即便交換操作會多一些,但實質上的交換只是對數組特定位置的賦值,這種操作還是挺快的。

  1. 從待排序數組中選一個值作為分區的參考界線,一般選***個元素即可。這個選出來的值可叫做樞軸pivot,它將會在一趟排序中不斷被移動位置,只終移動到位于整個數組的正確位置上。
  2. 一趟排序的目標是把小于樞軸的元素放在前方,把大于樞軸的元素放在后方,樞軸放在中間。這看起來一趟排序實質上所干的事情就是把數組分區。接下來考慮怎么完成一次分區。
  3. 記一個游標i,指向待排序數組的首位,它將會不斷向后移動;
    再記一個游標j,指向待排序數組的末位,它將會不斷向前移動。
    這樣可以預見的是,i 、j終有相遇時,當它們相遇的時候,就是這趟排序完成時。
  4. 現在讓游標j從后往前掃描,尋找比樞軸小的元素x,找到后停下來,準備把這個元素扔到前方去。
  5. 在同一個數組內排序并不能擴大數組的容量,那怎么扔呢?
    因為剛才把首位元素選作為pivot,所以當前它們的位置關系是pivot ... x。
    又排序目標是升序,x是個小值卻放在了pivot的后方,不妥,需要交換它們的位置。
  6. 交換完后,它們的位置關系變成了x ... pivot。此時j指向了pivot,i指向了x。
  7. 現在讓游標i向后掃描,尋找比樞軸大的元素y,找到后停下來,與pivot進行交換。
    完成后的位置關系是pivot ... y,此時i指向pivot,即pivot移到了i的位置。
  8. 這里有個小優化,在i向后掃描開始時,i是指向x的,而在上一輪j游標的掃描中我們已經知道x是比pivot小的,所以完全可以讓i跳過x,不需要拿著x和pivot再比較一次。
    結論是在j游標的交換完成后,順便把i往后移一位,i ++。
    同理,在i游標的交換完成后,順便把j往前移一位,j --。
  9. 在掃描的過程中如果發現與樞軸相等的元素怎么辦呢?
    因我們不討論三向切分的快排優化算法,所以這里答案是:不理它。
    隨著一趟一趟的排序,它們會慢慢被更小的元素往后擠,被更大的元素往前擠,***的結果就是它們都會和樞軸一起移到了中間位置。
  10. 當i和j相遇時,i和j都會指向pivot。在我們的分區方法里,把i返回,即在分區完成后把樞軸位置返回。
  11. 接下來,讓分出的兩個數組分別按上述步驟各自分區,這是個遞歸的過程,直到數組不能再分時,排序完成。

快速排序是很天才的設計,實現不復雜,關鍵是它真的很快~

各大排序算法的Objective-C實現以及圖形化演示比較

快速排序.gif

 

  1. - (void)jx_quickSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback { 
  2. if (self.count == 0) {  
  3. return 
  4.  
  5. [self jx_quickSortWithLowIndex:0 highIndex:self.count - 1 usingComparator:comparator didExchange:exchangeCallback];  
  6.  
  7. - (void)jx_quickSortWithLowIndex:(NSInteger)low highIndex:(NSInteger)high usingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback { 
  8. if (low >= high) {  
  9. return 
  10.  
  11. NSInteger pivotIndex = [self jx_quickPartitionWithLowIndex:low highIndex:high usingComparator:comparator didExchange:exchangeCallback]; 
  12. [self jx_quickSortWithLowIndex:low highIndex:pivotIndex - 1 usingComparator:comparator didExchange:exchangeCallback]; 
  13. [self jx_quickSortWithLowIndex:pivotIndex + 1 highIndex:high usingComparator:comparator didExchange:exchangeCallback];  
  14.  
  15. - (NSInteger)jx_quickPartitionWithLowIndex:(NSInteger)low highIndex:(NSInteger)high usingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback { 
  16. id pivot = self[low];  
  17. NSInteger i = low; 
  18. NSInteger j = high;  
  19. while (i < j) {  
  20. // 略過大于等于pivot的元素  
  21. while (i < j && comparator(self[j], pivot) != NSOrderedAscending) {  
  22. --;  
  23.  
  24. if (i < j) {  
  25. // i、j未相遇,說明找到了小于pivot的元素。交換。  
  26. [self jx_exchangeWithIndexA:i indexB:j didExchange:exchangeCallback];  
  27. i ++;  
  28.  
  29. /// 略過小于等于pivot的元素  
  30. while (i < j && comparator(self[i], pivot) != NSOrderedDescending) {  
  31. i ++;  
  32.  
  33. if (i < j) {  
  34. // i、j未相遇,說明找到了大于pivot的元素。交換。  
  35. [self jx_exchangeWithIndexA:i indexB:j didExchange:exchangeCallback];  
  36. --;  
  37.  
  38.  
  39. return i;  
  40. }

UI實現

現在講下UI的實現思路。

  1. NSMutableArray+JXSort.h 

從前面的排序代碼可以看到,我是給NSMutableArray寫了個分類,排序邏輯寫在分類里面,完全與視圖無關。

 

  1. typedef NSComparisonResult(^JXSortComparator)(id obj1, id obj2);  
  2. typedef void(^JXSortExchangeCallback)(id obj1, id obj2);  
  3. @interface NSMutableArray (JXSort)  
  4. // 選擇排序  
  5. - (void)jx_selectionSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback;  
  6. // 冒泡排序  
  7. - (void)jx_bubbleSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback;  
  8. // 插入排序  
  9. - (void)jx_insertionSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback;  
  10. // 快速排序  
  11. - (void)jx_quickSortUsingComparator:(JXSortComparator)comparator didExchange:(JXSortExchangeCallback)exchangeCallback;  
  12. @end 

外部調用者只需要傳入兩個參數:

  • comparator代碼塊。這是遵循蘋果原有API的風格設計,在需要比較數組內的兩個元素時,排序方法將會調用這個代碼塊,回傳需要比較的兩個元素給外部調用者,由外部調用者實現比較邏輯,并返回比較結果給排序方法。
  • exchangeCallback代碼塊。這個參數是實現視圖變化的關鍵。排序方法在每次完成兩個元素的交換時,都會調用這個代碼塊。外部調用者,比如ViewController就可以知道排序元素每一次變換位置的時機,從而同步視圖的變化。

 

  1. - (void)jx_exchangeWithIndexA:(NSInteger)indexA indexB:(NSInteger)indexB didExchange:(JXSortExchangeCallback)exchangeCallback {  
  2. id temp = self[indexA];  
  3. self[indexA] = self[indexB];  
  4. self[indexB] = temp 
  5. if (exchangeCallback) {  
  6. exchangeCallback(temp, self[indexA]);  
  7.  
  8.  
  9. ViewController.m 

視圖控制器持有待排序的數組,這個數組是100條細長的矩形,長度隨機。

  1. @property (nonatomic, strong) NSMutableArray *barArray; 

由于我們加強了NSMutableArray,它現在可以支持多種指定類型的排序了,同時也可以把排序過程反饋給我們,當需要給barArray排序時,只需要這樣調用:

 

  1. - (void)quickSort {  
  2. [self.barArray jx_quickSortUsingComparator:^NSComparisonResult(id obj1, id obj2) {  
  3. return [self compareWithBarOne:obj1 andBarTwo:obj2];  
  4. } didExchange:^(id obj1, id obj2) {  
  5. [self exchangePositionWithBarOne:obj1 andBarTwo:obj2];  
  6. }];  

每一次didExchange的回調,ViewController都會對兩個視圖的位置進行交換。如此形成不斷進行排序的視覺效果。

控制排序速度

為了能夠讓肉眼感知排序的過程,我們需要放慢排序的過程。

這里我的辦法是延長兩個元素比較操作的耗時,大約延長到0.002秒。結果很明顯,當某個算法所需要進行的比較操作越少時,它排序就會越快(根據上面四張圖的比較,毫無疑問快排所進行的比較操作是最少啦~)。

那么如何模擬出比較操作的耗時時間呢?

這里我的辦法是借助信號量,在兩條線程間通訊。

1.讓排序在子線程中進行,當需要進行比較操作時,阻塞線程,等待信號的到來。這里的思想是得到一個信號才能進行一次比較。

 

  1. - (NSComparisonResult)compareWithBarOne:(UIView *)barOne andBarTwo:(UIView *)barTwo {  
  2. // 模擬進行比較所需的耗時  
  3. dispatch_semaphore_wait(self.sema, DISPATCH_TIME_FOREVER);  
  4. CGFloat height1 = CGRectGetHeight(barOne.frame);  
  5. CGFloat height2 = CGRectGetHeight(barTwo.frame);  
  6. if (height1 == height2) {  
  7. return NSOrderedSame;  
  8.  
  9. return height1 < height2 ? NSOrderedAscending : NSOrderedDescending;  

2.主線程啟用定時器,每隔0.002秒發出一個信號,喚醒排序線程。

 

  1. self.sema = dispatch_semaphore_create(0);  
  2. NSTimeInterval nowTime = [[NSDate date] timeIntervalSince1970];  
  3. // 定時器信號  
  4. __weak typeof(self) weakSelf = self;  
  5. self.timer = [NSTimer scheduledTimerWithTimeInterval:0.002 repeats:YES block:^(NSTimer * _Nonnull timer) {  
  6. // 發出信號量,喚醒排序線程  
  7. dispatch_semaphore_signal(weakSelf.sema);  
  8. // 更新計時  
  9. NSTimeInterval interval = [[NSDate date] timeIntervalSince1970] - nowTime;  
  10. weakSelf.timeLabel.text = [NSString stringWithFormat:@"耗時(秒):%2.3f", interval];  
  11. }]; 

源碼https://github.com/JiongXing/JXSort

責任編輯:未麗燕 來源: 簡書
相關推薦

2016-12-07 10:42:57

排序算法實例

2013-06-20 10:40:32

Objective-C實現截圖

2012-01-11 09:15:45

Objective-C

2015-11-02 10:13:41

iOSObjective-C語法

2011-07-27 17:10:30

Objective-C 持久化

2011-07-19 17:24:31

Objective-C 對象

2013-03-26 10:35:47

Objective-C單例實現

2011-08-10 18:07:29

Objective-C反射

2013-03-27 12:54:00

iOS開發Objective-C

2011-05-11 15:58:34

Objective-C

2011-05-11 11:20:26

Objective-C

2014-11-25 10:18:17

Objective-C

2014-07-29 09:44:35

2013-04-11 13:41:30

Objective-CiOS編程

2011-08-04 11:15:46

Objective-C 構造函數 構造方法

2011-05-11 13:54:08

Objective-C

2011-05-11 14:06:49

Objective-C

2011-05-11 15:45:50

內存管理Objective-C

2011-08-04 14:58:37

Objective-C Cocoa NSString

2013-08-21 14:57:42

objective-c問題
點贊
收藏

51CTO技術棧公眾號

极品日韩av| 美女视频一区| 国产色91在线| 亚洲一区二区在线| 亚洲国产综合久久| 狠狠操综合网| 精品美女被调教视频大全网站| 成人免费毛片在线观看| 欧洲免费在线视频| 蜜臀久久久99精品久久久久久| 日韩有码在线播放| 一区二区三区四区影院| 综合毛片免费视频| 国产精品欧美综合在线| 成人精品一二区| 日本中文字幕在线| 91欧美日韩| 亚洲精品电影网在线观看| 日本老熟妇毛茸茸| 黄av在线播放| 久久综合狠狠综合| 91人人爽人人爽人人精88v| 日本一级淫片色费放| 久久中文字幕av一区二区不卡| 日韩精品一区二区在线观看| 男女曰b免费视频| 在线播放免费av| 成年人网站91| 国产免费观看久久黄| 青青青在线免费观看| 天堂综合网久久| 欧美人妇做爰xxxⅹ性高电影 | 久久久久久久久久婷婷| 欧美特黄一区二区三区| 日韩精品视频中文字幕| 色综合天天综合狠狠| 最新中文字幕久久| 欧美日韩伦理片| 国产99久久久国产精品免费看 | 久久一级免费视频| 日本中文字幕在线2020| caoporen国产精品视频| 国产欧美欧洲在线观看| 中文字幕视频网| 欧美日韩久久| 首页亚洲中字| 欧美日韩一区二区三区在线看| 91黄色免费看| 中文字幕国产日韩| 人妻无码一区二区三区| 免费观看性欧美大片无片| 欧美在线色视频| 动漫av网站免费观看| 精品视频在线一区二区| 国产日韩精品一区二区三区在线| 国产日韩欧美二区| 色综合天天做天天爱| 国产一区二区视频播放| 性xxxxfjsxxxxx欧美| 国产精品福利一区二区三区| 日韩精品资源| 国产午夜视频在线观看| 久久久久久9999| 免费国产一区二区| 午夜性色福利影院| 本田岬高潮一区二区三区| 成人夜晚看av| 黄色一级视频免费看| 亚洲女人av| 日本一区二区在线播放| 国产精品免费精品一区| 羞羞答答国产精品www一本| 91精品国产91久久| 日韩欧美亚洲一区二区三区| 亚洲区欧美区| 羞羞色国产精品| 免费看日韩毛片| 国产欧美激情| 日本欧美一二三区| 69视频免费看| 蜜桃视频一区二区三区 | 182在线视频观看| 亚洲午夜免费福利视频| 777精品久无码人妻蜜桃| 老色鬼在线视频| 欧美丝袜一区二区| 免费观看成人网| 亚洲三级在线| 日韩欧美亚洲另类制服综合在线 | 五月天色婷婷丁香| 欧美大片一区| 国内精品久久久久久久久| 国产污片在线观看| 肉肉av福利一精品导航| 国产精品视频久久| www.亚洲黄色| 久久久久综合网| 青春草在线视频免费观看| 尤物网在线观看| 国产精品的网站| 先锋影音一区二区三区| 国产在线观看免费麻豆| 亚洲男帅同性gay1069| 成人在线免费高清视频| 久久香蕉av| 欧美性猛交xxxxx免费看| 免费大片在线观看| 欧美日韩视频免费看| 日韩美女视频在线| 波多野结衣福利| 日韩精品中文字幕第1页| 久久影院在线观看| 久久在线视频精品| 国产精品日韩久久久| 国产精品色婷婷视频| www.色婷婷.com| 99久久精品久久久久久清纯| 天天综合狠狠精品| 日韩电影免费看| 91精品国产综合久久小美女| 日本一区二区三区网站| 亚洲字幕久久| 国产精品白嫩初高中害羞小美女| 亚洲毛片在线播放| 中文av一区二区| 青青青免费在线| 国产精品一级在线观看| 亚洲欧美日本另类| 久久久久久久久久一区二区三区| 日本成人中文字幕| 精品视频免费观看| av超碰免费在线| 欧美少妇一区二区| 国产白嫩美女无套久久| 欧美一区二区三区久久精品茉莉花| 日韩av片电影专区| 天堂av一区二区三区| 一区二区三区中文字幕在线观看| 九色91popny| 欧美激情影院| 欧美肥婆姓交大片| 一级特黄录像免费看| 91色视频在线| 青青草国产精品视频| 日韩精品视频在线看| 亚洲一级黄色av| 国产一级性生活| 国产一区福利在线| 亚洲欧美日韩精品在线| 亚洲一级少妇| 国产视频精品va久久久久久| 国产在线免费视频| 国产黄人亚洲片| 日韩精品福利片午夜免费观看| 欧美爱爱视频| 在线丨暗呦小u女国产精品| av大片在线免费观看| 成人白浆超碰人人人人| 激情成人开心网| 这里视频有精品| 欧美国产精品日韩| 免费在线观看污网站| 高清不卡一区| 自拍偷拍亚洲一区| 在线视频精品免费| 91色.com| 不卡影院一区二区| 国产欧美日韩免费观看| 国产www精品| 国产一级网站视频在线| 色噜噜狠狠成人中文综合| 老司机福利av| 天堂va蜜桃一区二区三区漫画版| 欧美国产一二三区| 日本在线视频一区二区| 一区二区欧美久久| 最近中文字幕免费观看| 国产精品免费久久| 免费黄频在线观看| 欧美三级小说| 久久亚洲免费| av一区在线播放| 久久九九全国免费精品观看| 99热这里只有精品在线观看| 亚洲已满18点击进入久久| 人妻体内射精一区二区三区| 亚洲深夜av| 日韩久久在线| 日韩视频一区二区三区四区| 久久全国免费视频| 欧美69xxxxx| 在线一区二区三区四区| 欧美日韩国产一二三区| 国产精品主播直播| 俄罗斯av网站| 国产韩国精品一区二区三区| 97久久夜色精品国产九色| 麻豆免费在线| 色婷婷久久一区二区| 性一交一乱一乱一视频| 日韩欧美在线国产| 中国美女黄色一级片| 国产盗摄精品一区二区三区在线| 欧美一级视频免费看| 欧美一区二区性| 99超碰麻豆| 91tv亚洲精品香蕉国产一区| 久久亚洲春色中文字幕| 亚洲av成人无码久久精品老人 | 日韩欧美一区二区三区在线视频 | 裸体大乳女做爰69| 日韩三区视频| 91精品网站| 日本一区二区电影| 欧美精品精品精品精品免费| 国产精品一二三区视频| 日本肉肉一区 | 一区二区三区视频免费| 国产毛片在线视频| 婷婷中文字幕综合| 91社区视频在线观看| 国产精品911| 国产熟女高潮视频| 国产精品a级| 五月天久久狠狠| 中文字幕av一区二区三区四区| 国产成人精品一区二区| 爱福利在线视频| 色香阁99久久精品久久久| 亚洲成a人片在线| 欧美日韩中文一区| 国产免费av一区| 亚洲中国最大av网站| 欧美性生交大片| 国产清纯在线一区二区www| 日韩综合第一页| 国产精品综合一区二区三区| 我看黄色一级片| 久久久久国产一区二区| 亚洲色成人www永久在线观看 | а√天堂资源国产精品| 97精品视频在线观看| 在线你懂的视频| 精品国产一区二区三区久久狼5月 精品国产一区二区三区久久久狼 精品国产一区二区三区久久久 | 久久一区国产| 久久久久久久久久久视频| 欧美成熟视频| 一级一片免费播放| 日韩精品首页| 亚洲精品视频一区二区三区| 色棕色天天综合网| 精品国产乱码久久久久久蜜柚| 一区中文字幕| 国产精品一区二区免费| 日本高清精品| 亚洲自拍欧美色图| 亚洲综合伊人| 91精品久久久久久综合乱菊 | 视频一区二区在线播放| 精品福利一区二区三区| 亚洲精品久久久狠狠狠爱| 欧美一级欧美一级在线播放| 国产精品一区二区人人爽| 欧美日韩小视频| 在线观看日批视频| 欧美日韩免费高清一区色橹橹 | 91精品国产一区二区三区蜜臀| 亚洲视频在线观看一区二区| 欧美日韩免费观看一区二区三区 | 538prom精品视频线放| 午夜亚洲视频| 欧美激情专区| 美女呻吟一区| 精品久久久久久中文字幕动漫| 日韩一二三区| 国产欧美日韩综合精品二区| 精品三级在线观看视频| 96pao国产成视频永久免费| 日韩精品中文字幕吗一区二区| 51午夜精品| 国产精品chinese在线观看| 91亚洲永久免费精品| 久久天天久久| 亚洲一区二区免费在线| 久久久久亚洲精品中文字幕| 999精品在线观看| 粉嫩精品导航导航| 久久影视中文粉嫩av| 成人精品亚洲| av磁力番号网| 亚洲美女黄网| 91看片就是不一样| 久久成人久久鬼色| 久久久久无码国产精品一区李宗瑞| 不卡的av电影在线观看| 97超碰在线资源| 国产精品不卡在线| 欧美特级一级片| 色婷婷av一区二区三区gif| 在线免费av网| 日韩av网址在线| 自拍视频在线| 久久久久久这里只有精品| 一区二区三区短视频| 国产色综合天天综合网| 操欧美女人视频| 日韩免费av一区二区三区| 国产电影一区二区在线观看| 亚洲高潮无码久久| 销魂美女一区二区三区视频在线| 亚洲综合欧美在线| av一区二区三区| 国产色无码精品视频国产| 亚洲国产成人精品视频| 波多野结衣在线观看一区| 亚洲成人黄色在线| 成人免费视频| 538国产精品一区二区免费视频| 黑人一区二区三区| 国产日韩二区| 91精品久久久久久久久久不卡| av免费观看网| 高清视频一区二区| 成人一级片免费看| 欧美日韩国产一区在线| av天堂一区二区三区| 在线视频日本亚洲性| 午夜不卡影院| 国产一级特黄a大片99| 97精品视频| 日本成人黄色网| 91视频在线观看免费| 久久这里只有精品国产| 91精品国产综合久久福利| 97电影在线观看| 45www国产精品网站| 日韩精品视频一区二区三区| 亚洲图色在线| 青青草国产精品97视觉盛宴| 91视频在线免费| 成人免费在线播放视频| 精品免费囯产一区二区三区| 亚洲国产99精品国自产| 精品精品导航| 91视频免费进入| 99热在线成人| 一个色综合久久| 中文字幕在线视频一区| 欧美在线视频精品| 亚洲午夜精品久久久久久久久久久久 | 美日韩一区二区| www.av欧美| 日韩欧美在线视频免费观看| 99久久久久久久| 久久久精品一区二区| 韩国成人在线| 日本午夜精品一区二区| 亚洲经典三级| 日本少妇毛茸茸| 黄色一区二区在线| 亚洲日本国产精品| **欧美日韩vr在线| 91亚洲精品视频在线观看| 精品一区二区三区毛片| 精品在线亚洲视频| 久久av红桃一区二区禁漫| 制服丝袜中文字幕一区| 日本性爱视频在线观看| 成人国产1314www色视频| 欧美日韩一区二区国产| 免费啪视频在线观看| 亚洲va在线va天堂| 天堂在线观看视频| 热久久这里只有精品| 国内成人自拍| 九九热精品国产| 亚洲乱码精品一二三四区日韩在线| 国产黄a三级三级看三级| 欧美精品激情在线观看| 天堂成人娱乐在线视频免费播放网站| aa在线免费观看| 国产欧美日韩中文久久| 免费看一级一片| 亚洲成人网在线观看| 91精品xxx在线观看| 日韩欧美一级在线| 国产亚洲精久久久久久| 精品国产亚洲一区二区麻豆| 人人澡人人澡人人看欧美| 亚洲五月综合| 久久精品老司机| 日韩一级黄色片| 99久久er| 国产a级一级片| 亚洲黄色免费网站| 粉嫩av一区| 国内外成人免费视频| 久久精品国产99| 草久视频在线观看| 九九热这里只有精品6|