String zerlegen

Hallo
ich möchte ein bisschen Java üben und habe mir folgende Übungsaufgabe rausgesucht.

Gegeben ist ein String mit Wörtern, die durch ein oder mehrere Leerzeichen
voneinander getrennt sind (Wort = beliebige Zeichenfolge ohne Leerzeichen). Geben
Sie eine Java-Methode woerterListe an, die aus einem solchen, als Parameter
woerter übergebenen String die einzelnen Wörter extrahiert und alle diese Wörter als
Liste zurückliefert:
LinkedList<String> woerterListe(String woerter) { ... }

mein problem ist nun das der int anfang, fest sitzt zwischen "Hallo" und "du".
ich weiß wirklich nicht, wie ich auf das nächste wort komm um es zu separieren.

gibt es vllt. auch eine elegantere Lösung, als so wie ich es probiere?


Java:
package Test;
import java.util.*;

class Test2 {
 
    public LinkedList<String> woerterListe(String woerter){
        LinkedList<String> liste1 = new LinkedList<String>();
        String hilf = " ";
        int anfang = 0;
       // int ende = 0;
        woerter = woerter.trim();
        woerter = woerter + hilf;
        while(woerter.length() > anfang){
          //  ende = woerter.indexOf("");
            hilf= woerter.substring(anfang,woerter.indexOf(" "));
            anfang = woerter.indexOf(" ");       // index von "" reinspeichern
            liste1.add(hilf);
        }
        
        return liste1;
    }
    
    public static void main(String[] args){
        Test2 run = new Test2();
        String woerter = "    Hallo du, du hast alles richtig gemacht!    ";
        LinkedList<String> liste = run.woerterListe(woerter);
        System.out.println(liste);
    }
}
 
G

Gast2

Gast
Musst du das so "manuell" machen? Die Klasse String kennt ne Methode split() mit der du das wunderbar lösen könntest.
 

Cola_Colin

Top Contributor
Java:
public LinkedList<String> woerterListe(String woerter){
  return new LinkedList<String>(Arrays.asList(woerter.split(" ")));
}
 
mit Index(Leerzeichen) + 1 hab ich mir auch schon gedacht, dann bekomm ich aber eine
(java.lang.StringIndexOutOfBoundsException: String index out of range: -1) Exception.

wenn ich split() benutzt muss ich den string woerter zu String[] woerter setzen, weil die einzelnen Worter ja dann in Arrays gespeichert werden. Aber der Kopf der methode ist vorgegeben.
Kann es sein das split(" ") gar nicht funktionieren würde, weil es eine Reguläre Expression sein müsste?
 

Cola_Colin

Top Contributor
Hmm ja, wenn die ganzen Leerstrings stören, dann muss man es noch anpassen, hast recht:

Java:
	public static void main(String[] args) {
		String test = "hallo welt    viele leeerzeichen   test";
		System.out.println(woerterListe(test));
	}
	
	public static LinkedList<String> woerterListe(String woerter){
		  return new LinkedList<String>(Arrays.asList(woerter.split(" +"))); //trenne bei einem oder mehreren leerzeichen
	}
 
Java:
public LinkedList<String> woerterListe(String woerter){
  return new LinkedList<String>(Arrays.asList(woerter.split(" ")));
}

dieser Code funktioniert, mit einem kleinen
Java:
woerter = woerter.trim()
noch davor. :)

würde trotzdem noch gerne wissen, was ich bei meinem Code ändern müsste damit es funktioniert. ;)
 

mla.rue

Bekanntes Mitglied
du solltest wirklich mit split arbeiten

zu deinem Problem: anfang = woerter.indexOf(" ") sucht immer und immer wieder bei jedem Durchang der Schleife nach dem ersten vorkommenden Leerzeichen, und das steckt wohl zwischen "Hallo" und "du". Solltest also "woerter" nach dem Zuweisen von "hilf" entsprechend anpassen ...
 
H

hüteüberhüte

Gast
Gegeben ist ein String mit Wörtern, die durch ein oder mehrere Leerzeichen
voneinander getrennt sind (Wort = beliebige Zeichenfolge ohne Leerzeichen). Geben
Sie eine Java-Methode woerterListe an, die aus einem solchen, als Parameter
woerter übergebenen String die einzelnen Wörter extrahiert und alle diese Wörter als
Liste zurückliefert:
LinkedList<String> woerterListe(String woerter) { ... }

Hätte das jetzt so implementiert, ohne irgendwelche Hilfsmethoden:

Java:
    public static LinkedList<String> woerterListe(String woerter) {
        LinkedList<String> result = new LinkedList<String>();
        
        int i = 0;
        while (i < woerter.length()) {
        while (i < woerter.length() && woerter.charAt(i) == ' ') {
            i++;
        }
        int j = i;
        while (i < woerter.length() && woerter.charAt(i) != ' ') {
            i++;
        }
        if (i != j) {
            result.add(woerter.substring(j, i));
        }
        }
        
        return result;
    }


    public static void main(String[] args) {
        System.out.println(woerterListe("bla   blaa blaaa  a    "));
    }

Jetzt noch kurz zur Erklärung Kommentare:

Java:
        LinkedList<String> result = new LinkedList<String>();
        
        int i = 0;
        // i = aktuell untersuchtes Zeichen
        while (i < woerter.length()) {
        while (i < woerter.length() && woerter.charAt(i) == ' ') {
            // übergehe alle Leerzeichen
            i++;
        }
        int j = i;
        // j = Position des ersten Nicht-Leerzeichens
        while (i < woerter.length() && woerter.charAt(i) != ' ') {
            i++;
            // übergehe alle Nicht-Leerzeichen
        }
        // i = Position des ersten Leerzeichens
        if (i != j) {
            result.add(woerter.substring(j, i));
        }
        }
        
        return result;

Also drei while-Schleifen. Klar würde das auf mit for-Schleifen funktionieren:

Java:
    public static LinkedList<String> woerterListe(String woerter) {
        LinkedList<String> result = new LinkedList<String>();
        
        for (int i = 0; i < woerter.length();) {
        for (; i < woerter.length() && woerter.charAt(i) == ' '; i++)
            ;
        int j = i;
        for (; i < woerter.length() && woerter.charAt(i) != ' '; i++)
            ;
        if (i != j) {
            result.add(woerter.substring(j, i));
        }
        }
        
        return result;
    }

Aber das ist mehr oder weniger Geschmackssache. Die einen bevorzugen das, die anderen das..

Grüße!
 
H

hüteüberhüte

Gast
Achja, ohne .substring müsstest du dir ein char[] erstellen, in das dann die einzelnen Zeichen kopiert werden. Aber denke mal, des ist auch klar
 

x22

Bekanntes Mitglied
@hüte und TO

in etwa so:

Java:
					char[] x= a.toCharArray();
					a= String.valueOf(x[0]);
					eins= Integer.parseInt(a)
 
H

hüteüberhüte

Gast
...das wäre ja nur ein Zeichen/Integer...:

Java:
    public static LinkedList<String> woerterListe(String woerter) {
        LinkedList<String> result = new LinkedList<String>();

        int i = 0;
        while (i < woerter.length()) {
            while (i < woerter.length() && woerter.charAt(i) == ' ') {
                i++;
            }
            int j = i;
            while (i < woerter.length() && woerter.charAt(i) != ' ') {
                i++;
            }
            if (i != j) {
                // result.add(woerter.substring(j, i));
                char[] ca = new char[i - j];
                for (int k = 0; j < i; k++, j++) {
                    ca[k] = woerter.charAt(j);
                }
                result.add(new String(ca));
            }
        }

        return result;
    }

Oder:

Java:
                // result.add(woerter.substring(j, i));
                int len = i - j;
                char[] ca = new char[len];
                for (int k = 0; k < len; k++) {
                    ca[k] = woerter.charAt(j + k);
                }
                result.add(new String(ca));

Freilich, ganz ohne zumindest den String-Konstruktor und .charAt geht es nicht...
 
H

hüteüberhüte

Gast
ok, hab mal nachgesehen, was bei .substring passiert:

GrepCode: java.lang.String (.java) - Class - Source Code View

http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/6-b14/java/lang/String.java#String.%3Cinit%3E%28int%2Cint%2Cchar[]%29

Es wird ein package private constructor aufgerufen, der mit demselben char[] (Referenz wird kopiert) ein neues String-Objekt erstellt/instantiiert. Das geht ja, weil sich das char[] nicht ändern darf.
Es werden also keine Zeichen kopiert. Damit sollte .substring schneller sein, als ein neues char[] zu erstellen
 
Zuletzt bearbeitet von einem Moderator:

ssoul26

Bekanntes Mitglied
Noch eine Lösung wäre:

Java:
   /**
    * Liefert die einzelnen Wörter aus einem String (BETA).
    * @param woerter
    * @return
    */
   public static LinkedList<String> woerterListe(String woerter) {
      LinkedList<String> liste1 = new LinkedList<String>();
      String wort = "";
      for (char c : woerter.toCharArray()) {
         if (c == 32) {
            if (wort.length() != 0) {
               liste1.add(wort);
               wort = "";
            }
         } else {
            wort += c;
         }
      }
      if (wort.length() != 0) {
         liste1.add(wort);
      }
      return liste1;
   }
 

ssoul26

Bekanntes Mitglied
StringBuffer würd a gehen. Stellt sich die Frage in wieweit Performance relevant ist? Wirst ja hoffentlich nicht einen String mit maximaler Stellenanzahl übergeben:)
 
H

hüteüberhüte

Gast
StringBuffer wird aber auch nicht schneller sein als .substring ;) und dafür benötigt man die Indices. Aber wenns Performance nicht geht um, dann egal
 
H

hüteü

Gast
.substring ist nicht langsam, schneller lässt sich das nicht implementieren, einigen wir uns darauf (langjährige erfahrung)
.
 
H

hüteüberhüte

Gast
StringKonkatenation dauert lange, Zeichen kopieren dauert lange, die Liste soll String s beinhalten => kann nicht erkennen, dass es schneller sein könnte ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
E String zerlegen aus args Java Basics - Anfänger-Themen 1
I Zerlegen von String Java Basics - Anfänger-Themen 3
L String zerlegen & elemente hinzufügen Java Basics - Anfänger-Themen 5
M String zerlegen anhand anderer String Java Basics - Anfänger-Themen 6
Orkanson Methoden String in Wörter zerlegen und Endungen der Wörter überprüfen. Java Basics - Anfänger-Themen 4
Silvascus String zerlegen Java Basics - Anfänger-Themen 6
H String zerlegen Java Basics - Anfänger-Themen 16
I String gezielt zerlegen Java Basics - Anfänger-Themen 5
D String zerlegen Java Basics - Anfänger-Themen 2
H String mit Leerzeichen in Variablen zerlegen Java Basics - Anfänger-Themen 4
T String zerlegen Java Basics - Anfänger-Themen 15
K Bestimmten String zerlegen Java Basics - Anfänger-Themen 12
H String zerlegen in einzelne Buchstaben (char)?? Java Basics - Anfänger-Themen 7
M String an bestimmten Stellen zerlegen Java Basics - Anfänger-Themen 12
M Integer.parseInt String zerlegen Java Basics - Anfänger-Themen 6
I String ohne Zeichen zerlegen lassen Java Basics - Anfänger-Themen 5
G String zerlegen? Java Basics - Anfänger-Themen 2
T String zerlegen? Java Basics - Anfänger-Themen 25
G String zerlegen Java Basics - Anfänger-Themen 14
M String zerlegen Java Basics - Anfänger-Themen 6
O String mit split zerlegen Java Basics - Anfänger-Themen 6
J String zerlegen mit mehreren trennzeichen Java Basics - Anfänger-Themen 3
Dilandau string intelligent zerlegen Java Basics - Anfänger-Themen 7
G string zerlegen? Java Basics - Anfänger-Themen 3
N String zerlegen und auf mehreren Variablen zuweisen Java Basics - Anfänger-Themen 3
richis-fragen String("AT") als StringObject-Variable deklarieren Java Basics - Anfänger-Themen 14
krgewb String mit Datumsangabe in Long umwandeln Java Basics - Anfänger-Themen 2
D String Groß/Kleinschreibung Ignorieren Java Basics - Anfänger-Themen 4
D Map<String, Integer> sortieren und der reinfolge nach die Glieder abfragen Java Basics - Anfänger-Themen 3
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
Kartoffel_1 String transformation Java Basics - Anfänger-Themen 7
H String-Operation replace() - Zeichenkette verdoppeln Java Basics - Anfänger-Themen 2
K String analysieren Java Basics - Anfänger-Themen 27
Beowend String zu Date parsen Java Basics - Anfänger-Themen 1
Beowend String auf Satzzeichen überprüfen? Java Basics - Anfänger-Themen 6
H Liste nach String-Länge sortieren Java Basics - Anfänger-Themen 1
String in ArrayList umwandeln Java Basics - Anfänger-Themen 1
I Sass Compiler und String erhalten? Java Basics - Anfänger-Themen 7
Avalon String in Double bzw. Währung konvertieren Java Basics - Anfänger-Themen 6
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
F Arraylist<String>Ein Wort pro Zeile Java Basics - Anfänger-Themen 6
J Schlüsselworte Prüfen, ob ein bestimmtes, ganzes Wort in einem String enthalten ist. Java Basics - Anfänger-Themen 6
N String überprüfen Java Basics - Anfänger-Themen 3
M Long-Typ in String-Änderung führt zu keinem Ergebnis bei großer Zahl Java Basics - Anfänger-Themen 11
Ostkreuz String Exception Java Basics - Anfänger-Themen 8
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
J String Filter Java Basics - Anfänger-Themen 5
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
XWing Randomizer mit einem String Java Basics - Anfänger-Themen 2
D 2D Char Array into String Java Basics - Anfänger-Themen 2
H Cast von Float nach String klappt nicht Java Basics - Anfänger-Themen 12
B Beliebiger String gegeben Suche Datum in String Java Basics - Anfänger-Themen 6
I String Java Basics - Anfänger-Themen 4
I API - zurückgegebener JSON String lesen und in Entity konvertieren Java Basics - Anfänger-Themen 2
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
W String einer Textdatei in einzelne Stringobjekte pro Zeile aufteilen Java Basics - Anfänger-Themen 14
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
M Kommandozeilenparamter als EINEN String werten Java Basics - Anfänger-Themen 5
M RandomAccessFile int und String gleichzeitig in einer Datei Java Basics - Anfänger-Themen 49
M Prüfen on eine Zahl im String enthalten ist Java Basics - Anfänger-Themen 3
Distanz zwischen zwei Zeichenfolgen in einem String bestimmen Java Basics - Anfänger-Themen 5
Substring in einem String finden Java Basics - Anfänger-Themen 13
BeginnerJava String mit vorgegebener Länge und Buchstaben erzeugen/ mit Leerstellen Java Basics - Anfänger-Themen 8
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
H Interface Wieso "List<String> list = new ArrayList<>[…]" Java Basics - Anfänger-Themen 4
JavaBeginner22 Integer in String umwandeln Java Basics - Anfänger-Themen 7
HolyFUT JSON String in Java Object schreiben - Anführungszeichen rauskriegen? Java Basics - Anfänger-Themen 17
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
HolyFUT Input/Output Leerzeichen aus String entfernen - klappt nicht! Java Basics - Anfänger-Themen 13
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
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
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
T String Array Fehler beim Index 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
X Datentypen String.equals funktioniert nicht Java Basics - Anfänger-Themen 5
Alen123 String wiederholen mit Schleifen Java Basics - Anfänger-Themen 1
A String split funktioniert nicht, wenn mehr als 1 Ziffer vor dem Zeichen steht nach dem er trennen soll? Java Basics - Anfänger-Themen 4
T String splitten Java Basics - Anfänger-Themen 3
sserio Schwimmen als Spiel. Problem mit to String/ generate a card Java Basics - Anfänger-Themen 4
J Datentypen String in File konvertieren funktioniert nicht Java Basics - Anfänger-Themen 4
T Platzhalter in String? Java Basics - Anfänger-Themen 14
M String mit Variable vergleichen Java Basics - Anfänger-Themen 9
I String Kombination erstellen anhand fortlaufender Zahl (Vertragsnummer) Java Basics - Anfänger-Themen 13
Fats Waller Compiler-Fehler Kann ich einen String und die Summe zweier Char Werte mittels der println Anweisung ausgeben Java Basics - Anfänger-Themen 4
M Wie kann eine Methode (string) eine andere Methode (void) mit zufälligen int-Werten aufrufen? Java Basics - Anfänger-Themen 4
P9cman Vokale in einem String überprüfen mittels Rekursion Java Basics - Anfänger-Themen 8
schredder Strings und reguläre Ausdrücke - Methode mit return string.matches Java Basics - Anfänger-Themen 5
R Ein Multidimensionales String Array initialisieren und Deklarieren Java Basics - Anfänger-Themen 2
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
Dorfschmied Kartesisches Produkt von zwei Liste mit Hashmaps<String,String> erstellen Java Basics - Anfänger-Themen 4
S String mit Int input vergleichen Java Basics - Anfänger-Themen 5
C String/Char-API Java Basics - Anfänger-Themen 13
U Char zu einem String machen Java Basics - Anfänger-Themen 1
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
T Leerzeichen im String entfernen Java Basics - Anfänger-Themen 6
Jose05 Nullpointerexception bei Umwandlung von String zu int Java Basics - Anfänger-Themen 2
O Ich habe einen String und soll mit matches schauen, ob ein Buchstabe zu einer geraden ANzahl im String vorkommt, wie soll das gehen? Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben