dasselbe nur mit anderem prinzip
parent
6636c36298
commit
8fb47e629e
|
@ -0,0 +1,102 @@
|
|||
|
||||
public class List<T>
|
||||
{
|
||||
private Node<T> first;
|
||||
private int length;
|
||||
private Node<T> last;
|
||||
/**
|
||||
* Konstruktor, legt leere Liste an
|
||||
*/
|
||||
public List(){
|
||||
this.first = null;
|
||||
length = 0;
|
||||
this.last= null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gibt zurück, ob die Liste leer ist (true heißt leer)
|
||||
*/
|
||||
public boolean isEmpty(){
|
||||
return this.first == null;
|
||||
}
|
||||
|
||||
/**
|
||||
* Gibt die Länge der Liste zurück
|
||||
*/
|
||||
public int size(){
|
||||
Node<T> current = this.first;
|
||||
int count= 0;
|
||||
while(current != null){
|
||||
current = current.next;
|
||||
count++;
|
||||
}
|
||||
|
||||
return length;
|
||||
}
|
||||
|
||||
public T get (int n){
|
||||
Node<T> current = this.first;
|
||||
for ( int i = 0; i < n ; i++ ){
|
||||
if (current == null)return null;
|
||||
current = current.next;
|
||||
}
|
||||
if (current == null ) return null;
|
||||
return current.wert;
|
||||
}
|
||||
|
||||
private Node<T> getNode (int n){
|
||||
Node<T> current = this.first;
|
||||
for ( int i = 0; i < n ; i++ ){
|
||||
if (current == null)return null;
|
||||
current = current.next;
|
||||
}
|
||||
if (current == null ) return null;
|
||||
return current;
|
||||
}
|
||||
|
||||
public void add (T val){
|
||||
Node<T> added = new Node<T>(val);
|
||||
Node<T> current = this.first;
|
||||
if (this.first == null){
|
||||
this.first = added;
|
||||
this.last = added;
|
||||
}
|
||||
else{
|
||||
this.last.next = added;
|
||||
this.last = added;
|
||||
}
|
||||
this.length++;
|
||||
}
|
||||
|
||||
public void add (int n, T val){
|
||||
Node<T> added = new Node<T>(val);
|
||||
if(this.getNode(n-1) == null)this.add(val);
|
||||
added.next = this.getNode(n-1).next;
|
||||
this.getNode(n-1).next = added;
|
||||
length++;
|
||||
}
|
||||
|
||||
public boolean contains (T val){
|
||||
Node<T> current = this.first;
|
||||
while(current != null){
|
||||
if(current.wert == val) return true;
|
||||
current = current.next;
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
public T remove(int n){
|
||||
if (this.length <= n ) return null;
|
||||
if ( n == 0) {
|
||||
T ret = this.first.wert;
|
||||
this.first = this.first.next;
|
||||
this.length--;
|
||||
return ret;
|
||||
}
|
||||
T ret = getNode(n).wert;
|
||||
if (getNode(n-1).next.next == null) this.last = getNode(n-1);
|
||||
getNode(n-1).next = getNode(n-1).next.next;
|
||||
length--;
|
||||
return ret;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,37 @@
|
|||
|
||||
public class Queue<T>
|
||||
{
|
||||
private Node<T> first;
|
||||
private Node<T> last;
|
||||
|
||||
public Queue(){
|
||||
this.first = null;
|
||||
this.last = null;
|
||||
}
|
||||
|
||||
public boolean isEmpty(){
|
||||
return this.first == null;
|
||||
}
|
||||
public void enqueue(T val){
|
||||
Node<T> added = new Node<T>(val);
|
||||
Node<T> current = this.first;
|
||||
if (this.first == null){
|
||||
this.first = added;
|
||||
this.last = added;
|
||||
}
|
||||
else{
|
||||
this.last.next = added;
|
||||
this.last = added;
|
||||
}
|
||||
}
|
||||
public T dequeue (){
|
||||
if (this.first == null) return null;
|
||||
T ret = this.first.wert;
|
||||
this.first = this.first.next;
|
||||
return ret;
|
||||
}
|
||||
public T front (){
|
||||
if (this.first == null) return null;
|
||||
return this.first.wert;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,27 @@
|
|||
|
||||
public class Stack<T>
|
||||
{
|
||||
private Node<T> first;
|
||||
|
||||
public Stack(){
|
||||
this.first = null;
|
||||
}
|
||||
public boolean isEmpty(){
|
||||
return this.first == null;
|
||||
}
|
||||
public void push(T val){
|
||||
Node<T> added = new Node<T>(val);
|
||||
added.next = this.first;
|
||||
this.first = added;
|
||||
}
|
||||
public T pop (){
|
||||
if (this.first == null) return null;
|
||||
T ret = this.first.wert;
|
||||
this.first = this.first.next;
|
||||
return ret;
|
||||
}
|
||||
public T top (){
|
||||
if (this.first == null) return null;
|
||||
return this.first.wert;
|
||||
}
|
||||
}
|
|
@ -15,7 +15,7 @@ public class test
|
|||
System.out.println(test.getNtenWert(2));
|
||||
System.out.println(test.getNtenWert(23));
|
||||
|
||||
LinkedList<String> test2 = new LinkedList<String>([{"Hallo", "Welt"}]);
|
||||
//LinkedList<String> test2 = new LinkedList<String>([{"Hallo", "Welt"}]);
|
||||
|
||||
|
||||
}
|
||||
|
@ -25,4 +25,11 @@ public class test
|
|||
|
||||
|
||||
}
|
||||
public static void testList(){
|
||||
List<Integer> l = new List<Integer>();
|
||||
l.add(1);
|
||||
l.add(3);
|
||||
l.remove(0);
|
||||
System.out.println(l.get(0));
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue