diff --git a/group09/85839593/assignment-0215-0226/pom.xml b/group09/85839593/assignment-0215-0226/pom.xml
new file mode 100644
index 0000000000..9d40995970
--- /dev/null
+++ b/group09/85839593/assignment-0215-0226/pom.xml
@@ -0,0 +1,15 @@
+
+
+
+ assignment
+ assignment
+ 1.0-SNAPSHOT
+
+ 4.0.0
+
+ assignment-0215-0226
+
+
+
\ No newline at end of file
diff --git a/group09/85839593/assignment-0215-0226/src/main/java/MyArrayList.java b/group09/85839593/assignment-0215-0226/src/main/java/MyArrayList.java
new file mode 100644
index 0000000000..0fbd7771b4
--- /dev/null
+++ b/group09/85839593/assignment-0215-0226/src/main/java/MyArrayList.java
@@ -0,0 +1,84 @@
+import java.io.IOException;
+import java.util.Iterator;
+import java.util.List;
+
+/**
+ * Created with IntelliJ IDEA.
+ * User: guohairui
+ * Date: 17-2-22
+ * Time: 上午12:06
+ * To change this template use File | Settings | File Templates.
+ */
+public class MyArrayList {
+ public int size = 0;
+ private Object [] elementData = new Object[5];
+ public void add(int index,Object obj){
+ if(index>size() ||index<0)
+ throw new IndexOutOfBoundsException("哎呀我去,不够了.");
+ elementData[index]=obj;
+ size++;
+ }
+ public void insert(int index,Object obj){
+ if(size>elementData.length-1){
+ System.out.println("当前size:" + size + " 当前length:" + elementData.length+",再插不够了,需要扩容");
+ Object [] tmpData = elementData;
+ elementData =new Object[size+5] ;
+ System.out.println("当前size:" + size + " 当前length扩了5后为:" + elementData.length);
+ System.arraycopy(tmpData,0,elementData,0,index);
+ elementData[index]=obj;
+ System.arraycopy(tmpData,index,elementData,index+1,tmpData.length-index);
+ }else {
+ if(elementData[index]==null){
+ elementData[index]=obj;
+ }else {
+ System.out.println("当前size:" + size + " 当前length:" + elementData.length);
+ System.arraycopy(elementData,index,elementData,index+1,size-index);
+ elementData[index]=obj;
+ }
+ }
+ size++;
+ }
+ public void add(Object obj){
+ if(size>=elementData.length){
+ System.out.println("当前size:" + size + " 当前length:" + elementData.length);
+ Object [] tmpData = elementData;
+ elementData =new Object[size+5] ;
+ System.out.println("当前size:" + size + " 当前length扩了5后为:" + elementData.length);
+ System.arraycopy(tmpData,0,elementData,0,size);
+ elementData[size]=obj;
+ }else {
+ System.out.println("当前size:" + size + " 当前length:" + elementData.length);
+ elementData[size]=obj;
+ }
+ size++;
+ }
+ public Object get(int index) {
+ if(index>=size)
+ throw new IndexOutOfBoundsException("越了");
+ return elementData[index];
+ }
+ public Object remove(int index){
+ Object delValue = elementData[index];
+ int movesize = size-index-1;
+ System.out.print("size:"+size+" index:"+index+" ,size-index-1:"+movesize);
+ System.arraycopy(elementData,index+1,elementData,index,movesize);
+ System.out.print("删除后前移位,数组末位清空");
+ elementData[--size]=null;
+
+ return delValue;
+ }
+ public int size(){
+ return size;
+ }
+ public String toString(){
+ StringBuilder sb = new StringBuilder();
+ sb.append('[');
+ for (int i=0;i=size)
+ throw new RuntimeException("超出范围了");
+ Node node = head;
+ if(index<(size>>1)){//当偏向于前一半时从头找,否则从尾找
+ for ( int i=0;i<=index;i++) {
+ node = node.next;
+ }
+ }else {
+ for (int i=size;i>index;i--){
+ node=node.previous;
+ }
+ }
+ return node;
+ }
+
+ private static class Node{
+ Object data;//当前Entry
+ Node next;//下一个
+ Node previous;//前一个
+ public Node(Object data,Node next,Node previous){
+ this.data=data;
+ this.next=next;
+ this.previous=previous;
+ }
+ }
+ public String toString(){
+ StringBuilder sb = new StringBuilder();
+ sb.append('[');
+ Node n =getNode(0) ;
+ for (int i=0;i>2);
+ }
+}
diff --git a/group09/85839593/assignment-0215-0226/src/test/java/MyLinkedListTest.java b/group09/85839593/assignment-0215-0226/src/test/java/MyLinkedListTest.java
new file mode 100644
index 0000000000..f0db06e6f8
--- /dev/null
+++ b/group09/85839593/assignment-0215-0226/src/test/java/MyLinkedListTest.java
@@ -0,0 +1,70 @@
+import org.junit.*;
+import org.junit.Test;
+
+/**
+ * Created with IntelliJ IDEA.
+ * User: guohairui
+ * Date: 17-2-26
+ * Time: 下午6:12
+ * To change this template use File | Settings | File Templates.
+ */
+public class MyLinkedListTest {
+ @org.junit.Test
+ public void testAdd() throws Exception {
+ MyLinkedList linkedList = new MyLinkedList();
+ linkedList.add("abc1");
+ linkedList.add("abc2");
+ linkedList.add("abc3");
+ linkedList.add("abc4");
+ System.out.println(linkedList.get(1));
+ System.out.println(linkedList);
+ linkedList.add("abc5");
+ System.out.println(linkedList.get(3));
+ System.out.println(linkedList.get(4));
+ System.out.println(linkedList);
+ linkedList.add(2,"abcaddtmp");
+ System.out.println(linkedList.get(3));
+ System.out.println(linkedList.get(4));
+ System.out.println(linkedList);
+ linkedList.remove(2);
+ System.out.println(linkedList.toString());
+ linkedList.removeLast();
+ System.out.println(linkedList.toString());
+ linkedList.removeFirst();
+ System.out.println(linkedList.toString());
+ }
+ @Test
+ public void testGet() throws Exception {
+
+ }
+
+ @Test
+ public void testRemove() throws Exception {
+
+ }
+
+ @Test
+ public void testAddFirst() throws Exception {
+
+ }
+
+ @Test
+ public void testRemoveFirst() throws Exception {
+
+ }
+
+ @Test
+ public void testRemoveLast() throws Exception {
+
+ }
+
+ @Test
+ public void testSize() throws Exception {
+
+ }
+
+ @Test
+ public void testGetNode() throws Exception {
+
+ }
+}
diff --git a/group09/85839593/assignment-0215-0226/src/test/java/MyQueueTest.java b/group09/85839593/assignment-0215-0226/src/test/java/MyQueueTest.java
new file mode 100644
index 0000000000..d93a70ba81
--- /dev/null
+++ b/group09/85839593/assignment-0215-0226/src/test/java/MyQueueTest.java
@@ -0,0 +1,29 @@
+import org.junit.*;
+import org.junit.Test;
+
+/**
+ * Created with IntelliJ IDEA.
+ * User: guohairui
+ * Date: 17-2-26
+ * Time: 下午7:33
+ * To change this template use File | Settings | File Templates.
+ */
+public class MyQueueTest {
+ @org.junit.Test
+ public void testEnQueue() throws Exception {
+ MyQueue myQueue=new MyQueue();
+ myQueue.enQueue("abc1");
+ myQueue.enQueue("abc2");
+ myQueue.enQueue("abc3");
+ System.out.println(myQueue);
+ myQueue.enQueue("abc4");
+ System.out.println(myQueue);
+ myQueue.deQueue();
+ System.out.println(myQueue);
+ }
+
+ @Test
+ public void testDeQueue() throws Exception {
+
+ }
+}
diff --git a/group09/85839593/assignment-0215-0226/src/test/java/MyStackTest.java b/group09/85839593/assignment-0215-0226/src/test/java/MyStackTest.java
new file mode 100644
index 0000000000..b96d77dbbf
--- /dev/null
+++ b/group09/85839593/assignment-0215-0226/src/test/java/MyStackTest.java
@@ -0,0 +1,36 @@
+import org.junit.*;
+import org.junit.Test;
+
+/**
+ * Created with IntelliJ IDEA.
+ * User: guohairui
+ * Date: 17-2-26
+ * Time: 下午7:20
+ * To change this template use File | Settings | File Templates.
+ */
+public class MyStackTest {
+ @org.junit.Test
+ public void testPush() throws Exception {
+ MyStack myStack = new MyStack();
+ myStack.push("abc1");
+ myStack.push("abc2");
+ myStack.push("abc3");
+ System.out.println(myStack);
+ myStack.push("abc4");
+ System.out.println(myStack);
+ System.out.println("myStack.peek:"+myStack.peek());
+ myStack.pop();
+ System.out.println("myStack.size"+myStack.size());
+ System.out.println(myStack);
+ }
+
+ @Test
+ public void testPop() throws Exception {
+
+ }
+
+ @Test
+ public void testPeek() throws Exception {
+
+ }
+}
diff --git a/group09/85839593/pom.xml b/group09/85839593/pom.xml
new file mode 100644
index 0000000000..627fff7a1f
--- /dev/null
+++ b/group09/85839593/pom.xml
@@ -0,0 +1,16 @@
+
+
+ 4.0.0
+
+ assignment
+ assignment
+ pom
+ 1.0-SNAPSHOT
+
+ assignment-0215-0226
+
+
+
+
\ No newline at end of file