Das Maximum einer Liste ermitteln

jura818

Mitglied
Hallo ,
ich hoffe ihr könnt mir helfen !Versuche eine Methode zu schreiben ,die das Maximum meiner Liste ermittelt .Hab aber leider gerade überhaupt keine Idee .Meine Liste:
Java:
class ListenElement2{
		
	ListenElement2 pre;
	ListenElement2 next;
	int inhalt;
	
	ListenElement2(){};
	
	ListenElement2(ListenElement2 ne,int in){
		
		next=ne;
		in=inhalt;
		
	}
		ListenElement2(ListenElement2 pr,ListenElement2 nex,int in){	
		pre=pr;
		next=nex;
		inhalt=in;
}
	
}


public class Liste2 {

	ListenElement2 root;
	

	boolean swap(int i,int j){//Methode zu vertauschen zweier Elemente 
		
		if(Math.max(i,j) >= laenge()){return false;}
		
				else{
					
			int aa = get(Math.min(i,j));
			set(Math.min(i,j),get(Math.max(i,j)));
			set(Math.max(i,j),aa);
			
		}
		
		return true;
		
	}
	
	boolean swap2(int i,int j){//Methode zu vertauschen zweier Elemente 
		
		if(Math.max(i,j) >= laenge()){return false;}
		
		ListenElement2 l1 = root;
		ListenElement2 l2 = root;
		
		for(int k = 0 ; k < Math.max(i, j); k++){
			if(k < Math.min(i,j)) l1 = l1.next;
			l2 = l2.next;
		
		}


	
	
		ListenElement2 temp1 = null;
		
		 l1.pre.next = l2;
		 l2.pre.next = l1;
		 temp1 = l1.pre;
		 l1.pre = l2.pre;
		 l2.pre = temp1; 
		 temp1 = l1.next;
		 l1.next = l2.next;
		 l2.next = temp1;

		 
		
		return true;
			

	}
int laenge(){
		int a = 0;
		ListenElement2 b = root;
		
		while(b != null){
			b = b.next;
			a++;}
		return a;}
	
	
		int get(int pos){
		
		int erg = 0;
		ListenElement2 b = root;
		
		if(pos < 0 || this.laenge() < pos){ System.out.println("falscher Index"); return Integer.MAX_VALUE;}
		else{
			for(int i = 0; i < pos; i++){
				b = b.next;}
			
			erg = b.inhalt;
			return erg;	
			} 
			
		}
	
		boolean set(int pos, int val){
		
		ListenElement2 b = root;
		if(pos < 0 || this.laenge() < pos){ System.out.println("falscher Index"); return false;}
		else{
			for(int i = 0; i < pos; i++){
				b = b.next;
			}
			
			b.inhalt = val;
			return true;				
		}
	}
Vielen Dank im vorraus
 

Dagobert

Bekanntes Mitglied
Guten Tag,
Du iterierst einfach durch deine Liste und merkst dir immer das größte Element, indem du das aktuelle Element mit dem größten vergleichts. Die Liste kann auch leer sein, das must du seperat behandeln.

mfg. Dagobert
 

Atze

Top Contributor
- erstes element der liste holen, speichern.
- die liste durchlaufen, aktuellen wert mit dem gespeicherten vergleichen, wenn dieser höher ist, alten wert mit aktuellem überschreiben
- wenn die liste durchlaufen ist, den gespeichernten wert zurückgeben

*edit* da war wieder einer schneller :)
 

goeoe7

Mitglied
Bevor ich zu deiner Frage komme ein paar Bemerkungen:

1.) Hast du davon schonmal was getestet? Ich wüsste nicht wie, weil dir z.B: ein Konstruktor für deine Liste fehlt und du imho einen kleinen Fehler bei deinem zweiten ListenElement2-Konstruktor gemacht hast, das müsste heißen
Java:
    ListenElement2(ListenElement2 ne,int in){
        
        next=ne;
        inhalt=in;
        
    }
2.) Ich gehe mal davon aus, dass du die Klasse für irgendeine AUfgabe selber schreiben MUSST, ansonsten kannst du natürlich einfach die vorimplementierte Methode LinkedList benutzen
3.) Ich kenne natürlich deine Aufgabenstellung nicht, aber wichtiger als Elemente zählen wäre im Moment imho eine einfügen-Methode, im Moment wird die Liste immer die Länge 0 haben

So, zu deiner Frage: Iteriere einfach durch die Liste durch (wie in laenge()) und vergleiche dabei immer das aktuelle Element mit dem bisherigen Maximum.

EDIT:
bei mir waren sogar 2 schneller, aber ich halte wie gesagt die fehlende maximums-Funktion für das eher sekundäre Problem bei dem obigen Code
 

jura818

Mitglied
Das ist sozusagen meine Einfügen Methode :
Java:
public static void main(String[] args) {
			
			Liste2 test = new Liste2();
			test.root = new ListenElement2();
			test.root.inhalt = 1;
			test.root.next = new ListenElement2(test.root,null,2);
			test.root.next.next = new ListenElement2(test.root.next,null,3);
			test.root.next.next.next = new ListenElement2(test.root.next,null,4);
						
			System.out.print(test.get(1) + " " + test.get(2));
			System.out.println(" ");
			test.swap(1,2);
			System.out.print(test.get(1) + " " + test.get(2));		
			System.out.println(" ");
			test.swap2(1,2);
			System.out.print(test.get(1) + " " + test.get(2));		
		
		
		
			
		}

	}

funktioniert auch alles einwandfrei ,nur halt die Maximum Methode .Hab das so versucht aber scheint nicht wirklich sinnvoll zu sein ,wobei auch zwei Fehler angezeigt werden .
Java:
ListenElement2 max(int inhalt){
			
			
			ListenElement2 max=null;
			
			
			for(ListenElement2 i =root;i!=null;i=i.next){
			
		if(i.inhalt.next>max)	
			
			max=i.inhalt.next;
			
			}
		return max;	
			
				
			
		}
 

goeoe7

Mitglied
Du willst in max doch den größten Wert, der vorkommt abspeichern, warum ist max dann ein ListenElement? Das muss ein int sein, dass du dann mit 0 oder (falls auch negative Werte in den Elementen stehen können) noch besser mit Integer.MIN_VALUE initialisierst

EDIT:
sorry, das ist noch nicht alles:

Java:
ListenElement2 max(int inhalt){
            
            
  int max=Integer.MAX_VALUE;
  for(ListenElement2 i =root;i!=null;i=i.next){        
    if(i.inhalt>max)
      max=i.inhalt;
    }
  return max;
}

Das müsste imho funktionieren
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Minimum/Maximum aus einer Liste Java Basics - Anfänger-Themen 3
M Maximum einer sinusfunktion (Spalt-Experiment) Java Basics - Anfänger-Themen 5
H Minimum und Maximum ausgeben lassen Java Basics - Anfänger-Themen 7
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
RudiRüssel Binäre Suche, unsortiert, lokales Maximum Java Basics - Anfänger-Themen 15
J Maximum herauskriegen mit foreach Java Basics - Anfänger-Themen 6
S Compiler-Fehler im array Maximum ermitteln Java Basics - Anfänger-Themen 6
hello_autumn Maximum berechnen. Java Basics - Anfänger-Themen 17
K Maximum Suchen Array Java Basics - Anfänger-Themen 6
R Erste Schritte Minimum und Maximum in Array finden Java Basics - Anfänger-Themen 29
D VM Argumente - Das Maximum rausholen Java Basics - Anfänger-Themen 19
V Maximum berechnen ... Java Basics - Anfänger-Themen 20
S JSplitPane Divider Maximum Position Java Basics - Anfänger-Themen 5
D Maximum Subarray Problem; Problem mit der Rückgabe Java Basics - Anfänger-Themen 10
S JAVA Methode für Maximum aus 4 ganzen Zahlen Java Basics - Anfänger-Themen 12
A Felder- Minimum/Maximum Java Basics - Anfänger-Themen 2
T aus Integer Array Maximum bestimmen Java Basics - Anfänger-Themen 7
M Maximum, Minimum und Mittelwert berechnen Java Basics - Anfänger-Themen 25
R maximum in integer array suchen Java Basics - Anfänger-Themen 29
B Applet, welches Maximum eines Array bestimmt Java Basics - Anfänger-Themen 2
P Lokales Minimum- Maximum, Globales Minimum - Maximum ? Java Basics - Anfänger-Themen 4
Z Zahlenreihe maximum Java Basics - Anfänger-Themen 3
U Maximum zweier Zahlen ermitteln Java Basics - Anfänger-Themen 7
D Maximum werte eines Arrays bestimmen !!!??? Java Basics - Anfänger-Themen 13
S maximum zweier Zahlen Java Basics - Anfänger-Themen 1
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
D 2 ArrayListen gleich sortieren bzw. eine Liste anhand einer anderen Sortieren Java Basics - Anfänger-Themen 6
ixChronos Letzten 4 Ziffern einer großen Zahl ausgeben Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Simon16 Java ArrayListe von einer Klasse sortieren Java Basics - Anfänger-Themen 2
Shadowrunner Variablen Gibt es eine Möglichkeit die Ziffern/Stellen einer Zahl fest zu legen? Java Basics - Anfänger-Themen 3
D remove Object von einer Liste von Obejcts Java Basics - Anfänger-Themen 3
FunkyPhil94 Wert in einer Lambda Funktion erhöhen Java Basics - Anfänger-Themen 3
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
B Kommunikation mit Seriellen Schnittstellen + Integration einer lib Java Basics - Anfänger-Themen 1
A Daten aus einer HashMap aus einer DB speichern und mit neuen Werten vergleichen Java Basics - Anfänger-Themen 8
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
D Länge einer Liste aufrufen. Java Basics - Anfänger-Themen 19
J Klassen Instanzen einer Klasse in einer anderen unabhängigen Klasse nutzen Java Basics - Anfänger-Themen 4
B Alle Strings bis zu einer Maimallänge aufzählen, die Bedingung erfüllen Java Basics - Anfänger-Themen 13
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
S Hilfe zu einer Aufgabe Java Basics - Anfänger-Themen 5
M Radius von einer ellipse bestimmen Java Basics - Anfänger-Themen 7
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
M Zufallszahl generieren mit einer linken und rechten Grenze Java Basics - Anfänger-Themen 3
N Was Passiert mit dem Namen einer Variable, wenn man diese einer Liste Hinzufügt Java Basics - Anfänger-Themen 16
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
W Objekte einer ArrayList in txt-datei schreiben mit Paths? Java Basics - Anfänger-Themen 2
S Best Practice Fragen zu Projektstruktur einer Datenbank-Abfrage-App (MVC) Java Basics - Anfänger-Themen 13
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
nelsonmandela Problem bei Ausgabe einer Switch - Case Funktion Java Basics - Anfänger-Themen 5
S Textausgabe in einer For-Schleife Java Basics - Anfänger-Themen 12
M Spezifischen Wert einer Zeile aus .txt Datei entnehmen Java Basics - Anfänger-Themen 15
B Popups mit Klicksabfangen zumAusfüllen einer .ods Datei Java Basics - Anfänger-Themen 0
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
E Suchfunktion in einer Liste Java Basics - Anfänger-Themen 39
T ungeordnete Werte-Paare in einer Liste Java Basics - Anfänger-Themen 7
FireHorses Einen Command erst nach einer Chateingabe aktivieren Java Basics - Anfänger-Themen 1
frager2345 Singleton-Muster Java ->Nur eine Instanz einer Klasse erzeugen können Java Basics - Anfänger-Themen 45
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
H Kapselung protected aber in einer Kindklasse nicht zugänglich Java Basics - Anfänger-Themen 5
R Methoden Werte einer ArrayList als Parameter übergeben. Java Basics - Anfänger-Themen 4
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
L Dauerhaftes Speichern einer Eingabe bei einer ArrayList Java Basics - Anfänger-Themen 26
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
stormyark Fehler beim überschreiben einer Variable Java Basics - Anfänger-Themen 1
H Kompliziertes Sortieren einer ArrayList mit Objekten(Sortieren nach X und Y) Java Basics - Anfänger-Themen 11
T Permanentes speichern von Objekten in einer ArrayList Java Basics - Anfänger-Themen 6
Saiko Zeilen einer Datei einlesen Java Basics - Anfänger-Themen 3
H Erste Schritte Nach einer Zahl n soll n Mal der String untereinander ausgegeben werden Java Basics - Anfänger-Themen 3
G zwei Instanzen einer Klasse Java Basics - Anfänger-Themen 29
sserio Prüfziffer einer ISBN Nummer herrausfinden. Java Basics - Anfänger-Themen 14
J Benennung einer mir unbekannten Java - Ausdrucksweise Java Basics - Anfänger-Themen 5
LFB In einer For-Schleife alles in einer Zeile ausgeben Java Basics - Anfänger-Themen 14
sserio Wie kann man nach einer Klasse fragen? Java Basics - Anfänger-Themen 12
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Wie gebe ich den Pfad zu einer Datei an, die in einem Ordner in Eclipse ist? Java Basics - Anfänger-Themen 1
M Variable in einer Schleife initialisieren Java Basics - Anfänger-Themen 46
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
J int innerhalb einer Datei ändern Java Basics - Anfänger-Themen 1
D Hilfe bei einer Aufgabe mit for-Schleife Java Basics - Anfänger-Themen 6
Neuling47 Ich zerbreche mit den kopf an einer Aufgabe Java Basics - Anfänger-Themen 61
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
J Zelleninhalt einer Jtable löschen Java Basics - Anfänger-Themen 2
Robert_Klaus Hamster java Simulation Hilfe bei einer Aufgabe Java Basics - Anfänger-Themen 5
stormyark 4 Bit in einer for-schleife funktioniert nicht Java Basics - Anfänger-Themen 3
F Werte in einer Arraylist Zählen Java Basics - Anfänger-Themen 2
M ArrayList mit einer Schleife befüllen Java Basics - Anfänger-Themen 2
A Ein Array bearbeiten und in einer anderen Methode nutzen Java Basics - Anfänger-Themen 6
A Ergebnis einer Methode bei einer anderen verwenden Java Basics - Anfänger-Themen 13
I Interface von einer EJB Klasse, um Code zu reduzieren Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben