Array-Filter

Swim

Mitglied
Hallo Leute,

derzeit versuche ich einen Filter für String-Arrays zu erstellen.
Es gib eine gewisse "Schranke" für die länge der jeweilige Strings in einem Array die nicht überboten werden darf.
Kleines Beispiel: Schranke: 5; String-Array:"Hallo","wie","geht","es","dir","Markus";
Wenn ich das Array durch den Filter laufen lasse soll dann folgendes Array zurückkommen:"wie","geht","es","dir". Dementsrechend werden "Hallo" und "Markus" aus dem Array geworfen, da sie länger bzw. gleich der Schranke sind.
Das hier ist mein Entwurf:
Java:
public class ArrayFilter {

	
	
	public static String[] filter(int schranke, String[] aList) {
		
		int l = aList.length;
		String[] kopie = new String[l];
		for (int i = 0; i < aList.length; i++) {
			kopie[i] = aList[i];
		}
		
		for (int i = 0; i < kopie.length; i++) {

			if (kopie[i].length() >= schranke) {
				kopie[i] = null;
				l = l -1;
			}
		}

		for (int i = 0; i < kopie.length; i++) {

			String a = kopie[i];

			if (a == null) {
				

				for (int t = i; t < kopie.length - 1; t++) {
					kopie[t] = kopie[t + 1];

				}

			}
			
			
		}
		
		String[] kopie2 = new String[l];
		for(int s = 0; s < l; s++){
			kopie2[s] = kopie[s];
		}
		
		

		return kopie2;
	}

	public static void main(String[] args) {

		int schranke = Integer.parseInt(args[0]);

		String[] liste = new String[args.length - 1];
		for (int i = 0; i < liste.length; i++)
			liste[i] = args[i + 1];

		String[] bList = filter(schranke, liste);

		for (int i = 0; i < bList.length; i++)
			System.out.println(bList[i]);

	}

}

Mein Problem ist allerdings, dass es nicht immer funktioniert.

Wenn ich jetzt z.B. als Args(5 abc 1234 dontaskme 4321 d zulang) nehme. Funktioniert es.
Wenn ich bei allerdings die Schranke auf 4 setzte kommt abc null raus. Wie kann das sein?
 
G

Gast2

Gast
Ich würd das ganze etwas simpler angehen.

Java:
public static String[] filter(int schranke, String[] aList) {
  // zählen wieviele Wörter im neuen Array sind
  // neues Array mit der Größe anlegen
  // gefilterte wörter ins neue Array setzen
}

Dann sparst du dir das ganze null setzen und rumgeschiebe.
 

Swim

Mitglied
// zählen wieviele Wörter im neuen Array sind
// neues Array mit der Größe anlegen

Klingt gut und ist auch versändlich, allerdings welche gefilterten Werte soll ich dann kopieren, wenn ich sie nicht markiert habe, wie in meinem Fall durch "null"?
 

TKausL

Top Contributor
// zählen wieviele Wörter im neuen Array sind
// neues Array mit der Größe anlegen

Klingt gut und ist auch versändlich, allerdings welche gefilterten Werte soll ich dann kopieren, wenn ich sie nicht markiert habe, wie in meinem Fall durch "null"?

Wozu markieren? Du kannst sie doch direkt in der Schleife checken und fals sie kurz genug sind ins neue Array kopieren.
 

Swim

Mitglied
Also ich soll zunächst schauen, wieviele Werte zu lange sind. Eine Kopie des Arrays mit der neuen Länge anlegen.
Soweit so gut, wie kann ich dann die zu Werte mit der richtigen Wortlänge in das neue Array kopieren?
Ich hab zwar die richtige Länge für das Array, aber die Wörter noch nicht.
 
D

Dow Jones

Gast
Der Fehler liegt in dem [c]if (a == null){...}[/c]-Block. Wenn du dort an Arrayposition i ein null findest kopierst du den Rest des Arrays (von Index i+1 bis Array.length) um eine Stelle nach vorne. Und dann machst du im nächsten Schleifendurchlauf mit Index i+1 weiter. Das ist jedoch Problematisch sobald mal zwei Nullpointer hintereinander auftreten, weil der jeweils zweite dadurch nicht behandelt wird.


Beispiel (der index i zeige immer auf das fettgedruckte Element):
Aktuelles Array, i sei = 1:
Code:
abc, [b]null[/b], null, null, d, null

Jetzt werden die Elemente von i+1 bis n um eine Stelle nach vorne kopiert.
Array nach dem kopieren:
Code:
abc, [b]null[/b], null, d, null, null

Jetzt müsste man eigentlich dasjenige Element, das neu auf die Position i gewandert ist, auf null hin überprüfen. Bei dir läuft die Schleife aber weiter; i wird erhöht, und zeigt dann schon auf das nächste Element.

Aktuelles Array, i sei jetzt = 2:
Code:
abc, null, [b]null[/b], d, null, null

Dadurch geht dir der Nullpointer an Position 1 durch die Lappen. Und wenn du ganz zum Schluss dein neues Array mit l (=2) Elementen zusammenstellst, dann erhälst du freilich die Elemente [c]abc, null[/c].


Ein einfacher Fix für dieses Problem wäre es in dem [c]if (a == null){...}[/c]-Block noch ein
Code:
i--;[/c] einzufügen, und die Schleife dann nicht bis [c]Array.length[/c] sondern nur bis [c]l[/c] laufen zu lassen:
[code=Java]
        for (int i = 0; i < l; i++) {
            String a = kopie[i];
            if (a == null) {
                for (int t = i; t < kopie.length - 1; t++) {
                    kopie[t] = kopie[t + 1];
                }
                i--;
            }
        }


Schöner wäre es aber wohl wenn du das Array einfach in einer Schleife durchläufst und dabei zwei unabhängige Indizes verwendest. Einen Index i für die Position an der das Array als nächstes ausgelesen wird, und einen zweiten Index j für die Position, an die das zuvor gelesene Element wieder in das Array hereingeschrieben werden soll. j wird nur dann um eins erhöht, wenn kein null-String vorliegt.

Java:
        int j=0;
        for (int i = 0; i < kopie.length; i++) {
            String a = kopie[i];
            if (a != null) {
                kopie[j] = kopie[i];
                j++;
            }
        }
 
D

Dow Jones

Gast
Huch, wo hast du denn den Begriff her? Eine Aufrufkonvention könnte man ganz allgemein als einen Weg um eine Funktion/Methode aufzurufen und ihr Daten zu übergeben (und Daten von ihr zurückzubekommen) beschreiben. Der Begriff wird allerdings eher in einem anderen Kontext verwendet (beim Bau von Compilern).

Wenn man bei Java-Quellcodes von Aufrufkonvention redet dann könnte ich mir vorstellen das man damit zwei verschiedene Dinge meinen kann:

1) die sog. Signatur einer Methode, z.B. [c]public static String[] filter(int schranke, String[] aList)[/c]. Hier wird festgelegt mit welchen Parametern in welcher Reihenfolge die Methode aufgerufen wird und was die Methode zurückliefert

2) die Unterscheidung zwischen Call by Value und Call by Reference.

Hilft dir das weiter?
 
G

Gast2

Gast
Java:
public static String[] filter(int schranke, String[] aList) {
  // zählen wieviele Wörter im neuen Array sind
  // neues Array mit der Größe anlegen
  // gefilterte wörter ins neue Array setzen
}
Das könnte man z.b. so umsetzen:
Java:
	public static String[] filter(int schranke, String[] aList) {
		int counter = 0;
		for (String s : aList) {
			if (s.length() < schranke) {
				counter++;
			}
		}
		
		String[] filtered = new String[counter];
		
		int itemCounter = 0;
		for (String s : aList) {
			if (s.length() < schranke) {
				filtered[itemCounter++] = s;
			}
		}
		
		return filtered;
	}
Find ich leichter verständlich als das null setzen, verschieben, etc.
 

Swim

Mitglied
Huch, wo hast du denn den Begriff her? Eine Aufrufkonvention könnte man ganz allgemein als einen Weg um eine Funktion/Methode aufzurufen und ihr Daten zu übergeben (und Daten von ihr zurückzubekommen) beschreiben. Der Begriff wird allerdings eher in einem anderen Kontext verwendet (beim Bau von Compilern).

Wenn man bei Java-Quellcodes von Aufrufkonvention redet dann könnte ich mir vorstellen das man damit zwei verschiedene Dinge meinen kann:

1) die sog. Signatur einer Methode, z.B. [c]public static String[] filter(int schranke, String[] aList)[/c]. Hier wird festgelegt mit welchen Parametern in welcher Reihenfolge die Methode aufgerufen wird und was die Methode zurückliefert

2) die Unterscheidung zwischen Call by Value und Call by Reference.

Hilft dir das weiter?

Dein erster (1.) Vorschlag hat mich überzeugt und müsste das Richtige sein.
Vielen Dank für die großartige Unterstützung.
 

escalate

Mitglied
Spricht irgendwas dagegen, einfach vernünftige Collections zu nehmen?

Immer noch nicht schön, aber immerhin einigermaßen übersichtlich:

Java:
	static List<String> filter(List<String> list, int maxLen) {
		List<String> filteredList = new ArrayList<>();
		for (String elem : list) {
			if (elem.length() <= maxLen)
				filteredList.add(elem);
		}
		return filteredList;
	}
 
Ä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