99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

合肥生活安徽新聞合肥交通合肥房產(chǎn)生活服務(wù)合肥教育合肥招聘合肥旅游文化藝術(shù)合肥美食合肥地圖合肥社保合肥醫(yī)院企業(yè)服務(wù)合肥法律

CHC5223代做、代寫java設(shè)計(jì)編程

時(shí)間:2024-05-20  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯(cuò)



CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 1 of 15 
Assignment 2 
Value 60% of coursework: Part A is 30% and Part B is 30% 
Individual work 
Learning outcomes 
Students will be able to understand 
1.1 Data structures 
1.2 The applications of data structures 
1.3 Object-oriented programming concepts 
1.4 Methods for program testing 
Students will have acquired skills in: 
2.1 Data abstraction 
2.2 The use of data structures 
2.3 Programming at a more advanced level in a high-level object-oriented language 
2.4 Program testing and documentation 
Students will have acquired skills in: 
3.1 Self-management 
3.2 Learning 
3.3 Communication 
3.4 Problem solving 
3.5 Information technology 
Submission requirements 
The assignment submitted should compressed into a .zip file, the following files should be 
contained in the compressed file: 
• a report as a Microsoft Word document containing text of all your classes. 
filename format: student ID+CHC5223_CW2_Report.docx 
• a .zip file containing the project: the runnable jar file (if available) and all the program’s 
source texts (.java), including those provided 
filename format: student ID +CHC5223_ CW2_Files.zip 
 
Part A – binary search tree 
General requirements 
All your programming must conform to “Java Conventions and Programming Guidelines” – see 
module Moodle site. 
You must paste the source code of all your classes into your report, as text or images. 
Introduction 
The topic of this part of the assignment is binary search trees. 
The interface IMemberDB describes methods for an abstract data type (ADT) which holds a 
database of Member objects. 
You must implement IMemberDB as a binary search tree for Assignment 2. 
You must not make any changes to these interfaces. CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 2 of 15 
Requirements 
Basic rules 
You must create one executable project after completing all tasks. 
One Java class should be defined in one .java file respectively. 
In the report, the source code of each task, together with the corresponding explanation, should 
be presented separately. 
Failure to comply with these rules will result in zero marks. 
 
Task 1 
You must create a Java class called MemberBST that implements the interface IMemberDB. 
You must use a binary search tree but it does not need to be self-balancing. 
You must not encapsulate existing implementations of collections in your submission. For 
example, you must not create a TreeMap object and call methods on that object from your class. 
Failure to comply with this will result in zero marks for that part. 
Tip: use String.compareTo to compare strings lexicographically. You can treat uppercase and 
lowercase as different. (Hash codes have no place in this assignment.) 
Methods can be implemented either iteratively or recursively. You must not implement the 
method remove by just building a new tree. 
You may make use of the supplied source code for the method remove, based on ObjectOriented
 Programming in Oberon-2, Hanspeter Mössenböck Springer-Verlag 1993, page 78, 
transcribed into Java by David Lightfoot (see Appendix). 
The constructor for MemberBST must print the string “Binary Search Tree” to System.out. 
Take care that you have not used a linear search O(n) where you should have used a binary 
search tree, aiming towards O(logn). 
5 marks 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
5 marks 
Task 2 
You must make appropriate use of assertions (assert statements) to protect preconditions of the 
operations. Remember to enable assertion checking for your project. 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
2 mark 
Task 3 
You must make your class log monitoring information, either to a text file or by calls of 
System.out.println. 
It must log (at least): 
• for every addition of a Member (put), for every retrieval of a Member(get), for every 
deletion of a Member(remove): 
o the Member name; CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 3 of 15 
o the sequence of nodes of the tree visited. 
• Paste your log into your report. 
We have supplied a main program CHC5223.java for your use with this assignment. 
The name of the file is set in the static variable filename. 
Sample files sampleMembersUK.csv and sampleMembersUS.csv each contain 500 members in 
this format. 
3 marks 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
3 mark 
Task 4 
 You must devise a test plan for your implementation. Be sure to check (among many other 
cases). 
• that deleting a leaf node works correctly 
• that deleting a node with one descendant works correctly 
• that deleting a node with two descendants works correctly 
2 marks 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
3 mark 
 
Task 5 
By using the supplied main program, or by other means, you must test your MemberBST. 
You must give clear evidence and detailed explanations of your test in the report, including your 
test plan, test data used, expected results and actual results. You must show your actual results 
and the logging information copied from your log file or the output pane of your IDE. Do not 
simply state “test passed”, or similar. 
5 mark 
 
Task 6 
You must comment on the time efficiency and space efficiency of your implementation of the 
binary search tree. 
You must give clear rationales and detailed explanations in the report. 
2 mark 
 
total 30 marks CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 4 of 15 
Part B – graphs and pathfinding 
The topic of this part of Assignment 2 is graphs and pathfinding. 
General requirements 
All your programming must conform to “Java Conventions and Programming Guidelines”. 
You must paste the source code of all your classes into your report, as text, not images. 
You must implement all necessary data structures using only arrays. 
When programming in Java it is usual to make use of collection classes from the Java class library. 
However, if you need to program in some other language such classes, or their equivalents, will 
not necessarily be available. 
Task 1 
Find or devise a transport network – it need not be real, but it must be realistic. It must be an 
undirected, connected graph, with no loops. It must have at least eight nodes. 
Each node should have a name (with no spaces in it) and x and y positions (0  x < 256 and 
0  y < 256) indicating the approximate position of the node on a map with a 256 × 256 grid (y 
increasing downwards). 
The links must contain information about the distance between the nodes it connects. The 
distance can be measured in suitable units of length, such as km, or time, such as minutes. 
The links between them must be such that there are several pairs of nodes that are linked by 
more than one route. 
You must sketch your network and include it in your report. The sketch must show each node 
annotated with its name and located on the sketch at its x and y position. The sketch must show 
each link annotated with its distance. You can make the sketch by hand but if you do so you will 
need to scan it to include in your report. 
2 marks 
 
Task 2 
You must express your network as a text file using the syntax: 
“station” name x y 
“link” station station distance 
Each station must have been defined in a station line before being cited in a link line. 
Include the content of the text file in your report. 
2 marks 
 
Task 3 
You must implement Java classes StackInt, QueueInt, ListInt and SetInt. These will be subclasses 
respectively of abstract classes AbsStackInt, AbsQueueInt, AbsListInt, AbsSetInt, whose source is 
provided and shown in the appendixes. These are given as abstract classes (to be ‘sub-classed’) 
rather than as interfaces (to be ‘implemented’) partly because they are all ‘bounded’, that is, 
with limited capacity because of being implemented by arrays, and also to allow us to give you 
hints on how to implement them. CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 5 of 15 
The required behaviour of the methods of the classes is indicated as pre- and post-conditions in 
comments. 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
4 marks 
 
Task 4 
You must make appropriate use of assertions (assert statements) to protect preconditions of the 
operations. Remember to enable assertion checking for your project. 
1 mark 
Task 5 
By using JUnit or otherwise you must test your implementations of StackInt, QueueInt, ListInt 
and SetInt. To do this, create objects of each class in which capacity is set to a low value, such as 
10. You will set it to something larger when deploying the classes later. 
You must give clear evidence and detailed explanations of your design and implementation in 
the report, including the test plan, test data used, expected results, and actual results. Your 
actual results must be shown either as screenshot images or as text copied from the output 
pane of the development toolkit. 
4 marks 
Task 6 
You must create a Java class StationInfo to implement the Java interface IStationInfo (supplied). 
1 mark 
Task 7 
You must create a Java class to define an adjacency matrix 
final double NO_LINK = Double.MAX_VALUE; // was erroneous double.MAX_VALUE 
int numStations; // 0 <= numStations <= capacity 
 
double distance[ ][ ]; 
where, for all i, j in 0 <= numStations <= capacity 
 distance [i][j] is the distance from station with number i to station with number j 
 distance [i][j] is equal to distance [j][i] 
 distance [i][i] = NO_LINK 
 
Task 8 
and also define a list of objects of class StationInfo held in an array. 
 
Task 9 
You must create a Java method in this class that reads a text file containing the textual 
description of your network and builds the corresponding list of stations and the matrix of links. CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 6 of 15 
You must perform as many validity checks in this as you can and report any errors. Include the 
text of this class in your report. 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
2 marks 
 
Task 10 
Use print statements to show the contents of the list and the matrix after using your program to 
build them from the data held in your text file. Copy the results into your report. 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
2 marks 
 
Task 11 
You must write Java methods (as in Appendixes) to perform a depth-first traversal from a given 
node of your network and a breadth-first traversal from the same node, making use of the 
algorithms given in the appendix. Include the methods text and the resulting sequence of node 
names in your report. 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
4 marks 
 
 
Task 12 
You must implement Dijkstra’s algorithm (as in Appendix) making use of the data structures you 
have constructed, to find and display the shortest path between two stations in your network. 
You must also ‘instrument’ your implementation to count the number of iterations of the while 
loop 
You must give clear rationales and detailed explanations of your design and implementation in 
the report. 
4 marks 
 
 
Task 13 
You must give clear rationales and detailed explanations of the difference between Dijkstra’s 
algorithm and A* algorithm and state how their behavior would differ in the case of your 
network. 
4 marks 
 
total 30 marks 
 CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 7 of 15 
Obtaining help 
It is encouraged to request further clarification on what is required for this assignment. Please 
try to do this during normal contact time and avoid asking for such help in the last week before 
the deadline. 
You can discuss the requirements and the material covered in the assignment with others but 
what you create must be all your own work. Be careful to avoid collusion. 
Declare in your report any help you have received other than that from the module teaching 
team. 
Feedback 
In addition to the written feedback that we aim to provide within the normal interval, you will be 
able to obtain fast, brief, verbal formative feedback and help on correcting your work at your 
practical classes. CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 8 of 15 
Appendix: remove 
private class Node { 
 private Member data; 
 private Node left, right; 
 public Node(Member s) {data = s; left = null; right = null;} 
} // Node 
 
private Node root; 
 
public Member remove(String name){ 
 // based on Object-Oriented Programming in Oberon-2 
 // Hanspeter Mössenböck Springer-Verlag 1993, page 78 
 // transcribed into Java by David Lightfoot 
 
 // put assert statement for preconditions here 
 
 Node parent = null, del, p = null, q = null; 
 Member result; 
 del = root; 
 while (del != null && !del.data.getName().equals(name)) { 
 parent = del; 
 if (name.compareTo(del.data.getName()) < 0) 
 del = del.left; 
 else 
 del = del.right; 
 }// del == null || del.data.getName().equals(name)) 
 
 if(del != null) { // del.data.getName().equals(name) 
 // find the pointer p to the node to replace del 
 if (del.right == null) p = del.left; 
 else if (del.right.left == null) { 
 p = del.right; p.left = del.left; 
 } else { 
 p = del.right; 
 while (p.left != null) {q = p; p = p.left;} 
 q.left = p.right; p.left = del.left; p.right = del.right; 
 } 
 if(del == root) root = p; 
 else if (del.data.getName().compareTo(parent.data.getName()) < 0) 
 parent.left = p; 
 else parent.right = p; 
 // reduce size of tree by one 
 result = del.data; 
 } 
 else result = null; 
 
 return result; 
 } // remove CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 9 of 15 
Appendix Abstract class AbsListInt 
package CHC5223; // or whatever 
/** 
 * Abstract class to be sub-classed by class(es) that represent lists of ints 
 * 
 * You may change the package name for this, but you should not 
 * modify it in any other way. 
 * 
 */ 
abstract public class AbsListInt { 
 protected int list[]; 
 protected int size; // 0 <= size <= capacity 
 protected final int capacity; 
 
 /** 
 * @param capacity -- maximum capacity of this list 
 * @post new list of current size zero has been created 
 */ 
 public AbsListInt(int capacity){ 
 // implements a bounded list of int values 
 this.capacity = capacity; 
 this.size = 0; 
 list = new int[capacity]; 
 } 
 
 public int getCapacity() {return capacity;} 
 public int getSize() {return size;} 
 
 /** 
 * @param n node to be added 
 * @pre getSize() != getCapacity() 
 * @post n has been appended to list 
 */ 
 abstract public void append(int n); 
 
 /** 
 * @param x -- value to be sought 
 * @pre true 
 * @return true if x is in list*/ 
 abstract public boolean contains(int x); 
 
} CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 10 of 15 
Appendix Abstract class AbsQueueInt 
package CHC5223; // or whatever 
/** 
 * Abstract class to be sub-classed by class(es) that represent stacks of ints 
 * 
 * You may change the package name for this, but you should not 
 * modify it in any other way. 
 * 
 */ 
abstract public class AbsQueueInt { 
 
 protected int queue[]; 
 protected int size; // 0 <= size <= capacity 
 protected final int capacity; 
 
 public AbsQueueInt(int capacity){ 
 this.capacity = capacity; 
 this.size = 0; 
 this.queue = new int[capacity]; 
 } 
 
 public int getCapacity() {return capacity;} 
 public int getSize() {return size;} 
 
 /** 
 * @param n node to be added 
 * @pre getSize() != getCapacity() 
 * @post n has been added to back of queue 
 */ 
 abstract public void addToBack(int n); 
 
 /** 
 * @pre getSize() != 0 
 * @post element at front of queue has been removed 
 * @return value that has been removed */ 
 abstract public int removefromFront(); 
 
} CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 11 of 15 
Appendix Abstract class AbsSetInt 
package CHC5223; // or whatever 
/** 
 * Abstract class to be sub-classed by class(es) that represent stacks of ints 
 * 
 * You may change the package name for this, but you should not 
 * modify it in any other way. 
 * 
 */ 
 
abstract public class AbsSetInt { 
 
 protected int set[]; 
 protected int size; // 0 <= size <= capacity 
 protected final int capacity; 
 
 /** 
 * @param capacity -- maximum capacity of this queue 
 * @pre capacity >= 0 
 * @post new set of current size zero has been created 
 */ 
 public AbsSetInt(int capacity){ 
 this.capacity = capacity; 
 this.size = 0; 
 this.set = new int[capacity]; 
 } 
 public int getCapacity() {return capacity;} 
 public int getSize() {return size;} 
 
 /** 
 * @param x -- value to be sought 
 * @pre true 
 * @return true iff x is in list*/ 
 abstract public boolean contains(int x); 
 
 /** 
 * @param n node to be added 
 * @pre contains(n) || getSize() != getCapacity() 
 * @post contains(n) 
 */ 
 abstract public void include(int n); 
 
 /** 
 * @pre true 
 * @post !contains(n) 
 */ 
 abstract public void exclude(int n); 
 
} CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 12 of 15 
Appendix Abstract class AbsStackInt 
package CHC5223; // or whatever 
/** 
 * Abstract class to be sub-classed by class(es) that represent stacks of ints 
 * 
 * You may change the package name for this, but you should not 
 * modify it in any other way. 
 * 
 */ 
 
abstract public class AbsStackInt { 
 
 protected int stack[]; 
 protected int size; // 0 <= size <= capacity 
 protected final int capacity; 
 
 /** 
 * @param capacity -- maximum capacity of this queue 
 * @pre capacity >= 0 
 * @post new stack of current size zero has been created 
 */ 
 public AbsStackInt(int capacity){ 
 this.capacity = capacity; 
 this.size = 0; 
 stack = new int[capacity]; 
 } 
 public int getCapacity() {return capacity;} 
 public int getSize() {return size;} 
 
 /** 
 * @param n node to be added 
 * @pre getSize() != getCapacity() 
 * @post n has been pushed on to top of stack 
 */ 
 abstract public void push(int n); 
 
 /** 
 * @pre getSize() != 0 
 * @post element on top of stack has been removed 
 * @return value that has been removed */ 
 abstract public int pop(); 
 
 /** 
 * @pre getSize() != 0 
 * @return value on top of stack */ 
 abstract public int peek() ; 
 
} CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 13 of 15 
Interface IStationInfo 
package CHC5223; // or whatever 
/** 
 * Interface to be implemented by class(es) that represent 
 * information about stations 
 * 
 * You may change the package name for this, but you should not 
 * modify it in any other way. 
 * 
 */ 
public interface IStationInfo { 
 
 /** 
 * @return the name of the station 
 */ 
 String getName(); 
 
 /** 
 * @return x position -- 0 <= getxPos() < 256 
 */ 
 int getxPos(); 
 
 /** 
 * @return y position -- 0 <= getyPos() < 256 
 */ 
 int getyPos(); 
} CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 14 of 15 
Appendix: breadth-first traversal, beginning with a specified start station 
Let Q be an empty queue of Stations 
Let L be an empty list of Stations 
Add the start station to the back of Q 
while Q is not empty do 
 Remove the Station at the front of Q, call this Station S 
 if S is not in list L then 
 Append S to L 
for each station S2 that is adjacent to S do 
 if S2 is not in the list L then 
 Add S2 to the back of queue Q 
 endif 
 endfor 
endif 
endwhile 
return L 
Appendix: depth-first traversal, beginning with a specified start station. 
Let S be a stack of Stations 
Create an initially empty list of Stations, which we will call L 
Push the start station on to the stack S 
while S is not empty do 
 Pop the Station at the top of the stack. Call this Station T. 
 if T is not already in list L then 
 add it to the back of that list 
 endif 
 for each station T2 that is adjacent to T do 
 if T2 is not in the list L then 
 push it on to the top of the stack S 
 endif 
 endfor 
endwhile 
return L 
 CHC5223 Data Structures and Algorithms 2023–2024 Semester 2 
 15 of 15 
Appendix: Dijkstra’s algorithm for shortest path in a network 
set Closed to be empty 
add all nodes in the graph to Open. 
set the g-value of Start to 0, and the g-value of all the other nodes to ∞ 
set previous to be none for all nodes. 
while End is not in Closed do 
 let X be the node in Open that has the lowest g-value (highest priority) 
 remove X from Open and add it to Closed. 
 if X is not equal to End then 
 for each node N that is adjacent to X in the graph, and also in Open do 
 let g’ = g-value of X + cost of edge from N to X 
 if g’ is less than the current g-value of N then 
 change the g-value of N to g’ 
 make N’s previous pointer point to X 
 endif 
 endfor 
 endif 
endwhile 
reconstruct the shortest path from Start to End by following “previous” pointers to find the 
previous node to End, the previous node to that previous node, and so on. 
 
請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp










 

掃一掃在手機(jī)打開當(dāng)前頁
  • 上一篇:代做COMP2K、代寫Python程序設(shè)計(jì)
  • 下一篇:中國人申請菲律賓簽證 菲律賓簽證的辦理地點(diǎn)
  • 無相關(guān)信息
    合肥生活資訊

    合肥圖文信息
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計(jì)優(yōu)化
    急尋熱仿真分析?代做熱仿真服務(wù)+熱設(shè)計(jì)優(yōu)化
    出評 開團(tuán)工具
    出評 開團(tuán)工具
    挖掘機(jī)濾芯提升發(fā)動(dòng)機(jī)性能
    挖掘機(jī)濾芯提升發(fā)動(dòng)機(jī)性能
    海信羅馬假日洗衣機(jī)亮相AWE  復(fù)古美學(xué)與現(xiàn)代科技完美結(jié)合
    海信羅馬假日洗衣機(jī)亮相AWE 復(fù)古美學(xué)與現(xiàn)代
    合肥機(jī)場巴士4號線
    合肥機(jī)場巴士4號線
    合肥機(jī)場巴士3號線
    合肥機(jī)場巴士3號線
    合肥機(jī)場巴士2號線
    合肥機(jī)場巴士2號線
    合肥機(jī)場巴士1號線
    合肥機(jī)場巴士1號線
  • 短信驗(yàn)證碼 豆包 幣安下載 AI生圖 目錄網(wǎng)

    關(guān)于我們 | 打賞支持 | 廣告服務(wù) | 聯(lián)系我們 | 網(wǎng)站地圖 | 免責(zé)聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網(wǎng) 版權(quán)所有
    ICP備06013414號-3 公安備 42010502001045

    99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

          9000px;">

                国产午夜精品理论片a级大结局| 成人av在线观| 日韩三级视频在线看| 一本一道综合狠狠老| 五月婷婷激情综合| 综合激情成人伊人| 国产免费久久精品| 91精品国产综合久久精品app| 亚洲丝袜精品丝袜在线| 欧美变态tickling挠脚心| 成人一区二区三区视频 | 精品人伦一区二区色婷婷| 成人黄色小视频| 裸体在线国模精品偷拍| 日本欧美一区二区三区乱码| 亚洲欧美经典视频| 一区二区三区免费网站| 国产日本亚洲高清| 国产精品免费看片| 国产视频一区在线观看| 在线看不卡av| 欧美少妇bbb| 日本道在线观看一区二区| 欧美综合天天夜夜久久| 成人黄色网址在线观看| 一本久久精品一区二区| 成人在线视频一区| 欧美在线一二三四区| 欧美少妇一区二区| 日韩精品一区二区三区四区| 精品国产91乱码一区二区三区 | 最新不卡av在线| 国产三级欧美三级| 久久天天做天天爱综合色| 国产视频在线观看一区二区三区| 日韩免费观看2025年上映的电影 | 日韩精品亚洲专区| 日日夜夜免费精品| 国产成人午夜片在线观看高清观看| 久草热8精品视频在线观看| 99精品国产99久久久久久白柏| 99精品欧美一区二区三区小说 | 日本道精品一区二区三区| 99久久精品国产观看| 一本一道综合狠狠老| 日韩欧美美女一区二区三区| 精品久久久久久久久久久久久久久| 一区二区在线观看av| 免费观看一级特黄欧美大片| 激情综合五月婷婷| 欧美图片一区二区三区| 91精品国产综合久久香蕉的特点| 欧美大片日本大片免费观看| 中文字幕综合网| 日韩精品亚洲一区| 91蝌蚪国产九色| 欧美肥妇毛茸茸| 久久色在线观看| 亚洲一级二级三级在线免费观看| 爽爽淫人综合网网站| 成年人午夜久久久| 在线电影国产精品| 国产亚洲欧美日韩俺去了| 婷婷激情综合网| 国产成人自拍网| 日韩一区二区视频在线观看| 国产精品美女一区二区| 亚洲18色成人| 成人黄色免费短视频| 欧美日韩和欧美的一区二区| 国产欧美中文在线| 婷婷成人激情在线网| 日本aⅴ亚洲精品中文乱码| 国产大陆精品国产| 亚洲一级片在线观看| 国产白丝网站精品污在线入口| 欧美色图12p| 日韩美女视频一区| 韩国视频一区二区| 精品国产自在久精品国产| 亚洲午夜精品在线| 久久国产三级精品| 欧美成人精品二区三区99精品| 亚洲欧美一区二区不卡| 成+人+亚洲+综合天堂| 精品久久久久久无| 综合久久久久久| 在线观看国产日韩| 国产精品久久久久久福利一牛影视 | 亚洲午夜免费福利视频| 国产91丝袜在线播放| 91免费小视频| 亚洲制服丝袜av| 色视频欧美一区二区三区| 国产精品久久久久久久午夜片 | 香蕉加勒比综合久久| 欧美午夜片在线观看| 国产精品久久久久aaaa樱花 | 555夜色666亚洲国产免| 亚洲不卡av一区二区三区| 色综合中文字幕国产 | jvid福利写真一区二区三区| 色94色欧美sute亚洲线路二| 欧美极品美女视频| 国产99精品在线观看| 欧美精品在欧美一区二区少妇| 中文字幕在线观看不卡视频| 国产福利一区在线| 中文字幕av一区二区三区免费看 | 91婷婷韩国欧美一区二区| 亚洲欧美乱综合| 色综合婷婷久久| 日韩精品成人一区二区三区| 欧美三级蜜桃2在线观看| 一区二区不卡在线播放 | 日韩精品专区在线影院观看| 日韩国产精品久久| 日韩女优毛片在线| www.欧美日韩| 亚洲激情综合网| 精品欧美乱码久久久久久 | 极品少妇xxxx精品少妇| 久久精品亚洲一区二区三区浴池| 久久99热这里只有精品| 亚洲欧美色图小说| 在线观看网站黄不卡| 亚洲国产经典视频| 欧美日韩日本视频| 亚洲午夜久久久久久久久电影网| 精品国产一区二区三区忘忧草| 国产一区二区三区免费看 | 国产日韩一级二级三级| 在线观看免费视频综合| 亚洲午夜久久久久久久久电影院| 欧美一级日韩免费不卡| eeuss影院一区二区三区| 亚洲在线观看免费视频| 中文字幕电影一区| 欧美图片一区二区三区| 亚洲精品水蜜桃| 欧美国产欧美综合| 欧美高清视频不卡网| 一本久久a久久精品亚洲| 日本视频一区二区| 亚洲综合网站在线观看| 久久新电视剧免费观看| 91成人在线精品| 91色porny| 韩国成人精品a∨在线观看| 午夜精彩视频在线观看不卡| 26uuu精品一区二区| 日韩三级中文字幕| 在线观看日韩电影| 美国毛片一区二区| 国产精品久久久久久久久快鸭 | 欧美日韩免费一区二区三区| 成人一道本在线| 美女视频黄 久久| 亚洲成av人**亚洲成av**| 国产日韩三级在线| 日韩一级高清毛片| 日韩美一区二区三区| 色婷婷香蕉在线一区二区| 成人动漫中文字幕| 国产一区二区视频在线| 中文字幕在线一区二区三区| 国产农村妇女毛片精品久久麻豆 | 亚洲第一精品在线| 亚洲国产欧美另类丝袜| 欧美—级在线免费片| 久久久久一区二区三区四区| 91精品国产乱码久久蜜臀| 欧美亚洲一区二区在线观看| 欧美视频在线一区二区三区| 97se狠狠狠综合亚洲狠狠| av成人老司机| av色综合久久天堂av综合| 99久久精品国产毛片| 成人av中文字幕| 成人av在线播放网址| 91免费国产视频网站| 99久久国产综合精品色伊| 欧美最新大片在线看 | 色综合色综合色综合| 欧美在线观看一区| 欧美在线不卡一区| 欧美大片拔萝卜| 久久综合99re88久久爱| 不卡视频一二三| 欧美精品丝袜中出| 欧美精品 国产精品| 国产三级欧美三级| 中文字幕精品综合| 一级女性全黄久久生活片免费| 一区二区三区高清| 久久久久久黄色| 亚洲综合激情小说| 午夜精品免费在线| 成人免费毛片片v| 不卡大黄网站免费看|