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

Java編程內(nèi)功-數(shù)據(jù)結(jié)構(gòu)與算法「棧(Stack)」

開(kāi)發(fā) 后端 算法
棧是限制線性表中元素的插入和刪除只能在線性表的同一端進(jìn)行的一種特殊線性表.允許插入和刪除的一端,為變化的一端,稱為棧頂(Top),另一端為固定的一端,稱為棧底(Bottom).

[[387145]]

 基本介紹

1. 棧是一個(gè)先入后出(FILO First In Last Out)的有序列表

2.棧是限制線性表中元素的插入和刪除只能在線性表的同一端進(jìn)行的一種特殊線性表.允許插入和刪除的一端,為變化的一端,稱為棧頂(Top),另一端為固定的一端,稱為棧底(Bottom).

3.根據(jù)棧的定義可知,最先放入棧中元素在棧底,最后放入的元素在棧頂,而刪除元素剛好相反,最后放入的元素最先刪除,最先放入的元素最后刪除.

棧的應(yīng)用場(chǎng)景

1.子程序的調(diào)用:在調(diào)往子程序前,會(huì)先將下個(gè)指令的地址存到棧中,直到子程序執(zhí)行完后再將地址取出,以回到原來(lái)的程序.

2.處理遞歸調(diào)用:和子程序的調(diào)用類似,只是除了儲(chǔ)存下一個(gè)指令的地址外,也將參數(shù)\區(qū)域變量等數(shù)據(jù)存入堆棧中.

3.表達(dá)式轉(zhuǎn)換(中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式)與求值(實(shí)際解決).

4.二叉樹(shù)的遍歷.

5.圖形的深度優(yōu)先(depth-first)搜索算法.

棧結(jié)構(gòu)實(shí)現(xiàn)案例

  1. package com.structures.stack; 
  2.  
  3. import java.util.Scanner; 
  4.  
  5. public class ArrayStackDemo { 
  6.     public static void main(String[] args) { 
  7.         ArrayStack stack = new ArrayStack(4); 
  8.         String key = ""
  9.         boolean loop = true
  10.         Scanner scanner = new Scanner(System.in); 
  11.         while (loop) { 
  12.             System.out.println("show:顯示棧"); 
  13.             System.out.println("exit:退出程序"); 
  14.             System.out.println("push:添加數(shù)據(jù)到棧(入棧)"); 
  15.             System.out.println("pop:從棧取出數(shù)據(jù)(出棧)"); 
  16.             key = scanner.next(); 
  17.             switch (key) { 
  18.                 case "show"
  19.                     stack.list(); 
  20.                     break; 
  21.                 case "push"
  22.                     System.out.println("請(qǐng)輸入一個(gè)數(shù)"); 
  23.                     int value = scanner.nextInt(); 
  24.                     stack.push(value); 
  25.                     break; 
  26.                 case "pop"
  27.                     try { 
  28.                         int res = stack.pop(); 
  29.                         System.out.println("出棧的數(shù)據(jù)%d\n" + res); 
  30.                     } catch (Exception e) { 
  31.                         System.out.println(e.getMessage()); 
  32.                     } 
  33.                     break; 
  34.                 case "exit"
  35.                     scanner.close(); 
  36.                     loop = false
  37.                     break; 
  38.             } 
  39.         } 
  40.         System.out.println("程序退出"); 
  41.     } 
  42.  
  43. //定義一個(gè)類表示棧結(jié)構(gòu) 
  44. class ArrayStack { 
  45.     private int maxSize;//棧的大小 
  46.     private int[] stack;//數(shù)組模擬棧,數(shù)據(jù)就放入該數(shù)組 
  47.     private int top = -1;//top表示棧頂,初始化-1 
  48.  
  49.     public ArrayStack(int maxSize) { 
  50.         this.maxSize = maxSize; 
  51.         stack = new int[this.maxSize]; 
  52.     } 
  53.  
  54.     //判斷是否棧滿 
  55.     public boolean isFull() { 
  56.         return top == maxSize - 1; 
  57.     } 
  58.  
  59.     //判斷是否棧空 
  60.     public boolean isEmpty() { 
  61.         return top == -1; 
  62.     } 
  63.  
  64.     //入棧 
  65.     public void push(int value) { 
  66.         if (isFull()) { 
  67.             System.out.println("棧滿"); 
  68.             return
  69.         } 
  70.         top++; 
  71.         stack[top] = value; 
  72.     } 
  73.  
  74.     //出棧 
  75.     public int pop() { 
  76.         if (isEmpty()) { 
  77.             throw new RuntimeException("棧空"); 
  78.         } 
  79.         int value = stack[top]; 
  80.         top--; 
  81.         return value; 
  82.     } 
  83.  
  84.     //顯示棧的情況[遍歷棧] 
  85.     public void list() { 
  86.         if (isEmpty()) { 
  87.             System.out.println("棧空,沒(méi)有數(shù)據(jù)~~"); 
  88.             return
  89.         } 
  90.         for (int i = top; i >= 0; i--) { 
  91.             System.out.printf("stack[%d]=%d\n", i, stack[i]); 
  92.         } 
  93.     } 
  94.  

 使用棧完成表達(dá)式的計(jì)算(中綴表達(dá)式)

準(zhǔn)備兩個(gè)棧,數(shù)字棧和符號(hào)棧.

1.通過(guò)一個(gè)index值(索引),來(lái)遍歷表達(dá)式.

2.如果發(fā)現(xiàn)是一個(gè)數(shù)字就直接入數(shù)字棧.

3.如果是一個(gè)符號(hào),分情況考慮如果當(dāng)前符號(hào)棧為空,就直接入站.如果符號(hào)棧有操作符,就進(jìn)行比較.

  • 如果當(dāng)前操作符的優(yōu)先級(jí)小于或者等于棧中的操作符,就需要從數(shù)棧中pop兩個(gè)數(shù),再?gòu)姆?hào)棧中pop出一個(gè)字符,進(jìn)行運(yùn)算,將得到結(jié)果入數(shù)棧,然后當(dāng)前操作符入符號(hào)棧.
  • 如果當(dāng)前的操作符的優(yōu)先級(jí)大于棧中的操作符,就直接入棧.

4.當(dāng)表達(dá)式掃描完畢,就順序地從數(shù)棧和符號(hào)棧中pop出相應(yīng)的數(shù)和符號(hào),并運(yùn)行.

5.最后在數(shù)字棧只有一個(gè)數(shù)字,就是表達(dá)式的結(jié)果.

  1. package com.structures.stack; 
  2.  
  3. public class Calculator { 
  4.     public static void main(String[] args) { 
  5.         //表達(dá)式 
  6.         String expression = "700+2*6-2"
  7.         //數(shù)棧 
  8.         ArrayStack2 numStack = new ArrayStack2(10); 
  9.         //符號(hào)棧 
  10.         ArrayStack2 operStack = new ArrayStack2(10); 
  11.         int index = 0;//用于掃描 
  12.         int num1 = 0; 
  13.         int num2 = 0; 
  14.         int oper = 0; 
  15.         int res = 0; 
  16.         char ch = ' ';//將每次掃描得到的char保存到ch 
  17.         String keepNum = "";//用于拼接多位數(shù) 
  18.         while (true) { 
  19.             ch = expression.substring(indexindex + 1).charAt(0); 
  20.             //如果是運(yùn)算符 
  21.             if (operStack.isOper(ch)) { 
  22.                 //如果為空 
  23.                 if (operStack.isEmpty()) { 
  24.                     operStack.push(ch); 
  25.                 } else { 
  26.                     if (operStack.priority(ch) <= operStack.priority(operStack.peek())) { 
  27.                         num1 = numStack.pop(); 
  28.                         num2 = numStack.pop(); 
  29.                         oper = operStack.pop(); 
  30.                         res = numStack.cal(num1, num2, oper); 
  31.                         //把運(yùn)算的結(jié)果入數(shù)棧,當(dāng)前符號(hào)入符號(hào)棧 
  32.                         numStack.push(res); 
  33.                         operStack.push(ch); 
  34.                     } else { 
  35.                         operStack.push(ch); 
  36.                     } 
  37.                 } 
  38.             } else { 
  39.                 //當(dāng)處理多位數(shù)時(shí),不能立即入棧. 
  40.                 keepNum += ch; 
  41.                 //如果ch是expression的最后一位 
  42.                 if (index == expression.length() - 1) { 
  43.                     numStack.push(Integer.parseInt(keepNum)); 
  44.                 } else { 
  45.                     if (operStack.isOper(expression.substring(index + 1, index + 2).charAt(0))) { 
  46.                         numStack.push(Integer.parseInt(keepNum)); 
  47.                         keepNum = ""
  48.                     } 
  49.                 } 
  50.             } 
  51.             index++; 
  52.             //掃遍到最后就退出 
  53.             if (index >= expression.length()) { 
  54.                 break; 
  55.             } 
  56.         } 
  57.         while (true) { 
  58.             if (operStack.isEmpty()) { 
  59.                 break; 
  60.             } 
  61.             num1 = numStack.pop(); 
  62.             num2 = numStack.pop(); 
  63.             oper = operStack.pop(); 
  64.             res = numStack.cal(num1, num2, oper); 
  65.             numStack.push(res); 
  66.         } 
  67.         System.out.printf("表達(dá)式%s=%d\n", expression, numStack.pop()); 
  68.  
  69.     } 
  70.  
  71. class ArrayStack2 { 
  72.     private int maxSize;//棧的大小 
  73.     private int[] stack;//數(shù)組模擬棧,數(shù)據(jù)就放入該數(shù)組 
  74.     private int top = -1;//top表示棧頂,初始化-1 
  75.  
  76.     public ArrayStack2(int maxSize) { 
  77.         this.maxSize = maxSize; 
  78.         stack = new int[this.maxSize]; 
  79.     } 
  80.  
  81.     //返回當(dāng)前棧頂?shù)闹?不是pop 
  82.     public int peek() { 
  83.         return stack[top]; 
  84.     } 
  85.  
  86.     //判斷是否棧滿 
  87.     public boolean isFull() { 
  88.         return top == maxSize - 1; 
  89.     } 
  90.  
  91.     //判斷是否棧空 
  92.     public boolean isEmpty() { 
  93.         return top == -1; 
  94.     } 
  95.  
  96.     //入棧 
  97.     public void push(int value) { 
  98.         if (isFull()) { 
  99.             System.out.println("棧滿"); 
  100.             return
  101.         } 
  102.         top++; 
  103.         stack[top] = value; 
  104.     } 
  105.  
  106.     //出棧 
  107.     public int pop() { 
  108.         if (isEmpty()) { 
  109.             throw new RuntimeException("棧空"); 
  110.         } 
  111.         int value = stack[top]; 
  112.         top--; 
  113.         return value; 
  114.     } 
  115.  
  116.     //顯示棧的情況[遍歷棧] 
  117.     public void list() { 
  118.         if (isEmpty()) { 
  119.             System.out.println("棧空,沒(méi)有數(shù)據(jù)~~"); 
  120.             return
  121.         } 
  122.         for (int i = top; i >= 0; i--) { 
  123.             System.out.printf("stack[%d]=%d\n", i, stack[i]); 
  124.         } 
  125.     } 
  126.  
  127.     //返回運(yùn)算符的優(yōu)先級(jí),數(shù)字越大則優(yōu)先級(jí)越高. 
  128.     //假定目前操作符只有 +  - * / 
  129.     public int priority(int oper) { 
  130.         if (oper == '*' || oper == '/') { 
  131.             return 1; 
  132.         } else if (oper == '+' || oper == '-') { 
  133.             return 0; 
  134.         } else { 
  135.             return -1; 
  136.         } 
  137.     } 
  138.  
  139.     //判斷是不是一個(gè)運(yùn)算符 
  140.     public boolean isOper(char val) { 
  141.         return val == '+' || val == '-' || val == '*' || val == '/'
  142.     } 
  143.  
  144.     //計(jì)算方法 
  145.     public int cal(int num1, int num2, int oper) { 
  146.         int res = 0; 
  147.         switch (oper) { 
  148.             case '+'
  149.                 res = num1 + num2; 
  150.                 break; 
  151.             case '-'
  152.                 res = num2 - num1;//注意順序 
  153.                 break; 
  154.             case '*'
  155.                 res = num1 * num2; 
  156.                 break; 
  157.             case '/'
  158.                 res = num2 / num1;//注意順序 
  159.                 break; 
  160.         } 
  161.         return res; 
  162.     } 

 【編輯推薦】

 

責(zé)任編輯:姜華 來(lái)源: 今日頭條
相關(guān)推薦

2021-03-18 08:44:20

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-09 06:30:32

JAVA數(shù)據(jù)結(jié)構(gòu)算法

2021-04-13 09:37:41

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-12 09:07:09

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-17 09:27:36

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-08 06:28:57

JAVA數(shù)據(jù)結(jié)構(gòu)與算法稀疏數(shù)組

2021-03-10 08:42:19

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-23 08:33:22

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-26 08:40:28

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-15 09:36:44

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-14 08:27:40

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-22 10:07:45

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-07 09:26:37

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-16 09:40:52

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-13 07:34:56

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-24 10:41:04

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-04-23 09:12:09

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-11 08:53:20

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-05-08 08:28:38

Java數(shù)據(jù)結(jié)構(gòu)算法

2021-03-29 10:13:47

Java編程數(shù)據(jù)結(jié)構(gòu)算法
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

69堂精品视频在线播放| 欧美一级特黄aaaaaa| 不卡在线一区| 91麻豆精品国产综合久久久久久| 国产成年人在线观看| 国 产 黄 色 大 片| 免费中文字幕日韩欧美| 日韩中文字幕在线视频| 中文字幕第九页| 日韩免费小视频| 亚洲免费在线视频| 久久亚洲免费| 99久久精品无免国产免费| 一区二区国产在线观看| 精品国产依人香蕉在线精品| 荫蒂被男人添免费视频| 欧美电影在线观看网站| 五月婷婷久久丁香| 一区二区三区在线观看www| 黄色一级a毛片| 精品综合久久久久久8888| 欧美极品少妇全裸体| 在线视频第一页| 91精品国产自产精品男人的天堂| 色域天天综合网| 久青草视频在线播放| 最新真实国产在线视频| av中文字幕不卡| 成人免费网视频| 成年人av网站| 亚洲欧洲日本mm| 美女av一区二区| 久久久久久国产免费a片| 久久夜色精品国产噜噜av小说| 欧美二区三区91| 99视频在线视频| 不卡一二三区| 狠狠色噜噜狠狠狠狠97| 妺妺窝人体色777777| 成人免费视屏| 日韩美女视频一区二区| 亚洲蜜桃在线| 国产二区视频在线观看| 久久久一区二区| 另类欧美小说| 日韩电影在线观看完整版| 波多野结衣精品在线| 99国产超薄肉色丝袜交足的后果 | 91久久精品国产91性色tv| 国产av天堂无码一区二区三区| 免费污视频在线观看| 亚洲另类在线视频| 50度灰在线观看| 在线中文字幕-区二区三区四区| 国产精品久久久久影院老司| 亚洲免费久久| 黄色在线播放网站| 亚洲婷婷综合久久一本伊一区| 亚洲精品在线免费| 中文字幕在线播放| 136国产福利精品导航| 亚洲第一精品区| 亚洲小说区图片区都市| 亚洲综合视频在线| 美女扒开大腿让男人桶| 精品极品在线| 色屁屁一区二区| 中文字幕第21页| 久久亚洲人体| 欧美三级乱人伦电影| 国产精品自拍视频在线| 亚洲精品无播放器在线播放| 日韩视频一区在线观看| 欧洲熟妇的性久久久久久| 欧美人妖在线观看| 国产亚洲精品美女久久久久| 99精品中文字幕| 欧美91视频| 97国产suv精品一区二区62| 黄色片中文字幕| 免费的国产精品| 99国精产品一二二线| 欧美一区二区公司| 国产午夜精品福利| 日本xxxxx18| 毛片在线网站| 欧美日韩中文字幕精品| 亚洲无在线观看| 精品自拍偷拍| 一本色道久久88精品综合| 四虎永久免费地址| 亚洲精品精选| 国产美女精品视频| 好吊视频一二三区| 日本一区二区成人在线| 国产专区在线视频| 手机看片久久| 欧美成人国产一区二区| 久久丫精品忘忧草西安产品| 一区二区三区中文| 欧美一级成年大片在线观看| 一本色道久久综合精品婷婷| 成人精品在线视频观看| 亚洲精品电影在线一区| 成人福利电影| 欧美高清视频不卡网| 中文在线永久免费观看| 91精品国产乱码久久久久久| 91地址最新发布| 国产美女永久免费| 国产欧美精品一区二区色综合朱莉| 蜜桃视频成人在线观看| 国精产品一区一区三区四川| 日韩精品中文字幕一区二区三区| 99精品欧美一区二区| 999在线观看精品免费不卡网站| 国产日韩一区在线| 免费在线观看一级毛片| 亚洲a一区二区| 日本精品一区在线| 成人毛片免费看| 2020久久国产精品| 欧美一级特黄aaaaaa| 亚洲欧美色图小说| 我要看一级黄色大片| 亚洲三级性片| 91高清视频在线免费观看| 99久久精品免费看国产交换| 国产精品久久久久影院亚瑟| 国产视频在线视频| 欧美自拍视频| 97精品一区二区三区| 亚洲av永久纯肉无码精品动漫| 国产精品每日更新| 超碰av在线免费观看| 国产一区99| 国产成人精品久久| 免费理论片在线观看播放老| 欧美日韩一区二区三区| 六十路息与子猛烈交尾| 亚洲国产片色| 国产精品一区视频| 成人福利电影| 亚洲国产欧美一区二区三区久久| 久久久久久久久久久久久久久久久| 韩国成人精品a∨在线观看| 中文有码久久| 精品午夜av| 久久成年人免费电影| 国产精品无码天天爽视频| 亚洲欧洲成人精品av97| 亚洲男人天堂av在线| 五月精品视频| 亚洲中国色老太| 国产区美女在线| 精品成人私密视频| 国产成人亚洲欧洲在线| 久久奇米777| 久久人妻精品白浆国产| 欧美日韩亚洲在线观看| 国产裸体写真av一区二区| 菠萝菠萝蜜在线视频免费观看| 制服丝袜亚洲播放| 久久久久久久久久久久久久久久久 | 国产视频在线观看视频| 一区二区三区在线观看网站| 亚洲少妇一区二区三区| 一本久道久久综合婷婷鲸鱼| 蜜桃久久影院| 日本国产一区| 欧美黄色免费网站| 婷婷婷国产在线视频| 一本大道av伊人久久综合| 波多野结衣喷潮| 福利一区在线观看| 人妻有码中文字幕| 久久精品国产大片免费观看| 91精品久久香蕉国产线看观看| 538视频在线| 夜夜嗨av色综合久久久综合网| 国产内射老熟女aaaa∵| 精品国产乱码久久久久久虫虫漫画| 无码熟妇人妻av| 捆绑紧缚一区二区三区视频 | 中文字幕网站在线观看| 另类调教123区 | 欧美大片xxxx| 成人av网站在线观看免费| 成人三级视频在线播放| 亚洲va在线| 久久综合久久久| 自拍偷拍亚洲图片| 97视频在线观看免费高清完整版在线观看| 理论视频在线| 日韩欧美国产一区二区三区 | 老妇喷水一区二区三区| 裸体裸乳免费看| 一本久久青青| 91亚洲精品一区二区| 五月天av在线| 久久中文字幕视频| 国产乱视频在线观看| 日韩精品一区二区三区中文不卡| 无码无套少妇毛多18pxxxx| 亚洲精品乱码久久久久久久久| 国产伦精品一区二区三区妓女| 国产综合一区二区| 成人免费观看毛片| 韩日欧美一区| 97超碰免费观看| blacked蜜桃精品一区| 亚洲aaaaaa| 欧美xnxx| 日本久久久久久久久久久| av电影免费在线观看| 中文字幕国产亚洲| 性感美女福利视频| 日韩亚洲欧美一区| 在线观看中文字幕网站| 一本一道久久a久久精品综合蜜臀| 麻豆亚洲av熟女国产一区二| 中文字幕免费不卡在线| 精品国产无码在线观看| 99精品视频在线播放观看| 精产国品一二三区| 久久99国产精品尤物| 日本男人操女人| 亚洲一级在线| 97国产精东麻豆人妻电影| 国内精品久久久久久久97牛牛| 欧美三级午夜理伦三级老人| 日韩欧美综合| 性欧美videosex高清少妇| 精品精品99| 奇米888一区二区三区| 日韩精选在线| 精品免费国产| 精品视频高潮| 精品国产区在线| 欧美网色网址| 国精产品一区二区| 欧美大奶一区二区| 精品视频一区在线| 乱中年女人伦av一区二区| 国产一区二区不卡视频| 美国成人xxx| 精品在线一区| 少妇高潮一区二区三区| 欧美成人第一区| 在线亚洲a色| 欧洲av一区| 成人久久综合| 日本精品免费视频| 亚洲欧美综合| 国产日韩亚洲欧美在线| 亚洲一级黄色| 免费无遮挡无码永久视频| 亚洲一区国产| 国产精品涩涩涩视频网站| 蜜臀av亚洲一区中文字幕| 亚洲精品自拍网| 国产在线一区二区综合免费视频| 日本一本在线视频| 国产99精品视频| 亚洲精品乱码久久久久久久| 2020国产精品久久精品美国| 国产小视频自拍| 国产精品国产馆在线真实露脸| 国产真实乱在线更新| 亚洲一区在线观看视频| 日本午夜视频在线观看| 欧美在线免费播放| 国产毛片毛片毛片毛片毛片| 日韩美女一区二区三区| 香蕉视频黄在线观看| 日韩在线中文字幕| 国产精品一品| 国产精品黄视频| 国产精品亚洲欧美日韩一区在线| 99久久国产免费免费| 亚洲va久久| 异国色恋浪漫潭| 亚洲精选在线| 天美星空大象mv在线观看视频| 久久国产夜色精品鲁鲁99| 久草免费资源站| 国产午夜一区二区三区| 农村黄色一级片| 日韩欧美精品网址| 国产欧美一级片| 免费成人在线视频观看| 欧美极品美女电影一区| 欧美人体一区二区三区| 91久久久久久| 伊人久久大香线蕉av不卡| 爱爱爱视频网站| 国产精品普通话对白| 日韩av自拍偷拍| 久久综合一区二区| 午夜国产福利一区二区| 狠狠色狠狠色综合日日小说| 国产理论片在线观看| 亚洲精品一区二区三区不| 黄色一级片在线观看| 55夜色66夜色国产精品视频| 高清在线一区二区| 欧美亚洲免费高清在线观看| 综合一区二区三区| 日本男人操女人| 91丨porny丨首页| 永久看片925tv| 欧美色窝79yyyycom| 完全免费av在线播放| 精品毛片一区二区三区| 亚洲日韩欧美视频一区| 97人澡人人添人人爽欧美| 91久久久久久久一区二区| 精品日韩免费| 18禁免费无码无遮挡不卡网站| 国产成人免费视频精品含羞草妖精 | 国产亚洲自拍一区| 91精品国产乱码久久久张津瑜| 欧美一二三在线| 蜜芽在线免费观看| 国产精品久久久久秋霞鲁丝| 丝袜美腿综合| 免费无码毛片一区二三区| 国产黑丝在线一区二区三区| 国精品人伦一区二区三区蜜桃| 色999日韩国产欧美一区二区| 熟妇人妻中文av无码| 欧美贵妇videos办公室| 免费观看性欧美大片无片| 亚洲一区3d动漫同人无遮挡| 日本视频免费一区| 国产毛片欧美毛片久久久| 日韩欧美大尺度| 精品欧美不卡一区二区在线观看| 136fldh精品导航福利| 麻豆精品av| 欧美v在线观看| 91免费视频观看| 日韩毛片一区二区三区| 日韩精品在线观看网站| 涩涩涩视频在线观看| 快播亚洲色图| 日本中文字幕一区二区有限公司| 男人舔女人下部高潮全视频| 91国偷自产一区二区开放时间| 黄色在线视频观看网站| 国产精品av在线播放| 日韩精品dvd| 爱豆国产剧免费观看大全剧苏畅| 国产精品久久久久久久久久免费看 | xvideos国产在线视频| 97碰碰视频| 一区二区自拍| 久久人人爽人人爽人人片| 91久久精品日日躁夜夜躁欧美| 91青青在线视频| 91精品在线一区| 欧美日韩调教| 一区二区视频观看| 91久久人澡人人添人人爽欧美| 91网在线播放| 91香蕉亚洲精品| 亚洲人www| 精品欧美一区二区久久久| 欧美精品黑人性xxxx| 电影k8一区二区三区久久| 久久精品ww人人做人人爽| 日本不卡一区二区| 欧美成人精品欧美一| 亚洲精品国产精品乱码不99按摩 | 一区二区日本视频| 国产手机在线观看| 欧美亚洲国产一区在线观看网站| 婷婷激情在线| 国产精品日本一区二区| 美女精品一区| 国产一区二区精彩视频| 日韩经典一区二区三区| h1515四虎成人| 免费的av在线| 26uuu国产在线精品一区二区| 中文字幕精品在线观看| 欧美国产日韩一区二区在线观看| 亚洲瘦老头同性70tv| 亚洲天堂网2018| 午夜激情久久久| 淫片在线观看| 精品久久蜜桃| 紧缚捆绑精品一区二区| 日本中文在线播放| 久久精品中文字幕| 日韩av资源网| 色偷偷中文字幕| 在线视频国产一区| 2021天堂中文幕一二区在线观| 亚洲欧洲精品在线|