Array Sequent Zählen

Leno

Bekanntes Mitglied
Guten Abend ,

ich habe mal wieder ein Prob. Ich soll folgendes machen:

Geben Sie eine Java-Methode an, die in einem int-Feld mit mindestens einem Element die längste Sequenz (d. h. aufeinanderfolgender Feldelemente) gleicher Werte bestimmt. Das Ergebnis der Methode ist die ermittelte Länge der längsten Sequenz.
Beispiel: Für das Feld {0, 0, 1, 0, 0, 0, 3, 3, 1} wäre dies 3, weil 3 Nullen aufeinander folgen und keine längere Sequenz gleicher Werte vorhanden ist.

Ich komme einfach nicht weiter

Java:
public class Aufgabe9 {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub

		int[] feld = { 2, 2, 2, 2, 0, 0, 0, 0, 0, 0, 1, 1, 1 };

		System.out.println(berechnerSequenz(feld));

	}

	public static int berechnerSequenz(int[] feld) {

		int sequenz = 1;
		int tmp = 0;

		for (int i = 0; i <= feld.length - 2; i++) {

			// System.out.println("längste Sequenz "+ sequenz);

		

			if (  feld[i] == feld[i + 1]) {
				
				sequenz+=1;
			}

			
				
				
			
			
			
			

		}

	}
}


Irgendwie weis Ich das Ich die Sequenz speichern muss aber irgendwie überschreibe Ich den Wert dann immer ?? hat jemand eine elegante Lösung oder zumindest einen Lösungsansatz ?

Danke im voraus :)
 

Bolle52

Aktives Mitglied
Hi,

ich hab hier eine quick and dirty lösung für dich:

Java:
public static int sequenz(int[] sequenz) {
		int currNr;
		int lastNr = 0;
		
		int sequenzCount = 0;
		
		ArrayList<Integer> list = new ArrayList<Integer>();
		
		for(int i = 0; i < sequenz.length; i++) {
			if(i == 0) {
				lastNr = sequenz[i];
			} else {
				currNr = sequenz[i];
				/*
				 *  Wenn der Vorgänger den gleichen Wert wie der Nachfolger hat,
				 *  wird die Sequenz hochgezählt
				 */
				if(currNr == lastNr) {
					sequenzCount++;
				} 
				/*
				 *  Wenn der Vorgänger und der Nachvolger nicht identisch sind,
				 *  wird die SequenzAnzahl in einer Arraylist zwischengespeichert
				 *  und der Sequenzzähler wird wieder auf 0 gesetzt
				 */
				else {
					list.add(sequenzCount);
					sequenzCount = 0;
				}
				lastNr = sequenz[i];
			}			
		}
		
		Collections.sort(list);
		
		return list.get(list.size() - 1);
	}
 
F

Firephoenix

Gast
Immer erst überlegen wie man es selbst machen würde wenn man das programm ist:

-Fange mit der ersten Zahl an
-Merke dir die erste Zahl
-Zähle temporäre Sequenz um eins hoch
-Überprüfe nächste Zahl
-Wenn nächste Zahl = gemerte Zahl dann zähle Sequenz um eins hoch
-Ist nächste Zahl andere Zahl prüfe ob temporäre Sequenz größer ist als längste Sequenz (am anfang 0)
-Ist temporäre Sequenz größer speichere diese als längste Sequenz
-merke nächste Zahl
-setze temporäre Sequenz auf 0
-fange wieder neu an

So in etwa würde ich das lösen.

Gruß
 

Leno

Bekanntes Mitglied
Hi ,

danke dir erstmal . Also Ich muss für eine Klausur lernen und wir dürfen aus Arrays nicht viele komplexe sachen nutzen. Also der Prof gibt immer hinweise was man benutzen darf. Daher wir dürfen keine Array list nutzen nur die einfachsten Konstrukte aus Java .

Vielleicht geht das ja auch ohne Array list oder ??
 
F

Firephoenix

Gast
aktuelle zahl Speichern: int - variable
bisherige längste sequenz speichern: int - variable
aktuelle sequenzlänge speichern: int - variable
zahlenfeld: int-array
durch das array laufen: for schleife die array.length() mal durchläuft

sollte also mit recht einfachen mitteln zu realisieren sein
 

Leno

Bekanntes Mitglied
@ Firephoenix Danke aber irgendwie sitze Ich schon total lange an der Aufgabe und kriege das nicht hin auch mit deiner Beschreibung hast du vielleicht einen Source Code ??
 

Bolle52

Aktives Mitglied
@ Firephoenix Danke aber irgendwie sitze Ich schon total lange an der Aufgabe und kriege das nicht hin auch mit deiner Beschreibung hast du vielleicht einen Source Code ??

hier ohne collections

Java:
public static int sequenz(int[] sequenz) {
		int currNr;
		int lastNr = 0;
		
		int sequenzCount = 0;
		int maxSequenzCount = 0;
		
		for(int i = 0; i < sequenz.length; i++) {
			if(i == 0) {
				lastNr = sequenz[i];
			} else {
				currNr = sequenz[i];
				/*
				 *  Wenn der Vorgänger den gleichen Wert wie der Nachfolger hat,
				 *  wird die Sequenz hochgezählt
				 */
				if(currNr == lastNr) {
					sequenzCount++;
				} 
				/*
				 *  Wenn der Vorgänger und der Nachvolger nicht identisch sind,
				 *  wird die SequenzAnzahl in einer Arraylist zwischengespeichert
				 *  und der Sequenzzähler wird wieder auf 0 gesetzt
				 */
				else {
					if(sequenzCount > maxSequenzCount) maxSequenzCount = sequenzCount;
					sequenzCount = 0;
				}
				lastNr = sequenz[i];
			}			
		}
		
		return maxSequenzCount;
	}
 

Leno

Bekanntes Mitglied
Vielen Dank finde die Lösung sehr schön wäre so nicht drauf gekommen. Habe immer das Gefühl Ich verstehe die Themen aber dann scheitere Ich an so einer kleinen Aufgabe @ Boll52 , wie kann Ich besser werden? Ich schätze mal Übung macht den Meister ! Danke noch mal hast mir sehr geholfen.
 

Bolle52

Aktives Mitglied
Vielen Dank finde die Lösung sehr schön wäre so nicht drauf gekommen. Habe immer das Gefühl Ich verstehe die Themen aber dann scheitere Ich an so einer kleinen Aufgabe @ Boll52 , wie kann Ich besser werden? Ich schätze mal Übung macht den Meister ! Danke noch mal hast mir sehr geholfen.

Letzten endes hast du dir selbst schon gesagt wie du besser wirst: Übung macht den meister.

Du kannst dir kleine aufgaben stellen und mit der Zeit wirst du besser und stellst dich anspruchsvolleren Aufgaben. Aufgaben von Universitäten kannst du dir ja anschauen. manche stellen sie frei ins Internet als pdf. Daran kannst du dich versuchen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
L Gridmuster in einem Array Java Basics - Anfänger-Themen 2
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
G zweidimensionales int Array sortieren Java Basics - Anfänger-Themen 57
W Array ausgeben Java Basics - Anfänger-Themen 29

Ähnliche Java Themen

Neue Themen


Oben