dasselbe nur mit anderem prinzip

master
SimonDHG 2023-12-06 11:07:13 +01:00
parent 6636c36298
commit 8fb47e629e
4 changed files with 174 additions and 1 deletions

102
List.java Normal file
View File

@ -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;
}
}

37
Queue.java Normal file
View File

@ -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;
}
}

27
Stack.java Normal file
View File

@ -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;
}
}

View File

@ -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));
}
}