Methode über Leerzeichen

ocsme

Top Contributor
Guten Tag,

hier erstmal die Aufgabenstellung:
Schreiben Sie eine effiziente Methode, die die Länge der längsten Sequenz von
Leerzeichen in einem gegebenen String sucht und dabei möglichst wenig Zeichen im
String untersucht (Hinweis: Das Programm sollte schneller werden, wenn die Länge
der Sequenz von Leerzeichen zunimmt). Geben Sie außerdem die Zahl der
benötigten Vergleiche aus.

Das Thema hatte ich hier schon mal da wurde es über Binäresuche gelöst. Ich habe aber einen neuen Ansatz denn auch Ich hin bekomme bis jetzt :D

Ich fülle einen String mit Leerzeichen und vergleiche diese dann ob die Anzahl der Leerzeichen im String vorhanden sind. Mein Programm sieht bis jetzt so aus:
Java:
public class WhiteSpace {
   
    static boolean fault(String text) {
        return (text==null || text.length()==0);
    }
   
    static void lengthWhiteSpace(String text) {
        int vergleiche=0, sequenz=0;
       
        System.out.println(text.length());
               
        if(fault(text)) {
            sequenz=0;
            vergleiche=0;
        }
       
        if(!fault(text)) {
            String s="";
            for(int i=text.length();i>0;i--) {
                s+=" ";
                if(text.contains(s)) {
                    sequenz=s.length();
                    vergleiche++;
                }
            }
        }
       
        System.out.println("Vergleiche " + vergleiche);
        System.out.println("Sequenz " + sequenz);
    }
   
    public static void main(String[] args) {
        String text="adsf    adsfsafasdf      dsaf";
        lengthWhiteSpace(text);
       
    }
}

Mein Problem sind die Vergleiche.
Die Sequenz stimmt ja damit da ich durch den String laufe und die Anzahl immer wieder erhöhe vorher habe ich gefragt ob der String Null ist oder leer ist!
Wie bekomme ich das nun aber mit den Vergleichen hin?
Hat da vielleicht jemand eine Idee?

LG
 

Javinner

Top Contributor
Ich glaube, du musst den String mit dem Leerzeichen spliten, dann hast du ja die Anzahl der Elemente in dem String-Array, das dann verrechnen, fertig.
 

ocsme

Top Contributor
o_O ich glaube ich verstehe dich nicht so recht.
Meinst du etwas ich soll ein String Array erstellen dort dann 1,2,3,4,5,... etc. Leerzeichen abspeichern lassen mit einer Schleife so lange bis ich die Länge des übergebenen Strings habe.
Dann vergleiche ich jede Position also im String Array [0] = 1 Leerzeichen mit meinem übergebenen String und so weiter?
Dann hätte man die Antwort auch also Anzahl der vergleiche aber ist das nicht mega viel Aufwand?
LG
 

ocsme

Top Contributor
Hab es mal schnell runter gecodet so wie ich es meine vielleicht kann man das eher verstehen ;) als der Text :D
Java:
int length=text.length();
        String[] s = new String[length];
        for(int i=0;i<s.length;i++) {
            String test="";
            for(int j=0;j<=i;j++) {
                test+=" ";
            }
            s[i]=test;
        }
      
        for(int i=0;i<s.length;i++)
            System.out.println(s[i]);

Jetzt habe ich ein String Array mit Leerzeichen :D
 

Javinner

Top Contributor
Java:
public class SplitTheString
{

  
    public static void main(String[] args)
    {
        String zweiLeerZeichen = "- - -";
        System.out.println(leerzeichen(zweiLeerZeichen));
      
        String dreiLeerZeichen = " - - -";
        System.out.println(leerzeichen(dreiLeerZeichen));
      
        String vierLeerZeichen = "- - - - ";
        System.out.println(leerzeichen(vierLeerZeichen));
      
        String fuenfLeerZeichen = " - - - - ";
        System.out.println(leerzeichen(fuenfLeerZeichen));
    }

    public static int leerzeichen(String toCheck)
    {
          //Dein Code
    }

}
/** Output */
2
3
4
5

http://openbook.rheinwerk-verlag.de/javainsel9/javainsel_04_008.htm
 

ocsme

Top Contributor
so hab ich es nun gelöst.
Java:
        String text="iitextiiiiiiiiiiiiiiiitext";
        lengthWhiteSpace(text);
       
        int vergleich=0;
        boolean gefunden=true;
        int length=text.length();
       
        String[] s = new String[length];
        for(int i=0;i<s.length;i++) {
            String tmp="";
            for(int j=0;j<=i;j++) {
                tmp+="i";
            }
            s[i]=tmp;
        }

       
        for(int i=s.length-1;i>=0;i--)
            if(text.contains(s[i])&&gefunden) {
                System.out.println(s[i]);
                vergleich=text.length()-i-1;
                gefunden=false;
            }
       
        System.out.println(vergleich);


Leider verstehe ich nicht so ganz wie das mit dem split gehen soll :(
ich werde mir das nochmal genauer anschauen doch was bringt mir das überhaupt?
LG
 

JCODA

Top Contributor
Ich glaube ihr überseht eine wichtige Sache an der Aufgabenstellung.
Zuerst mal: ein split ist ja nicht besser (bzgl. den benötigten Vergleichen) als brute-force. (Einmal über String iterieren und zusammenhängende Leerzeichen zählen)
Wenn man während der Iteration weiß, dass die bisherig längste Sequenz 3 lang war. Dann kann ich beim letzten Buchstaben, der kein Leerzeichen war 3 weiter springen, und schauen, ob ein Leerzeichen vorliegt. d.h. ich im Fall dass eins vorliegt, muss ich nochmal zurück. Falls es aber kein Leerzeichen war, kann ich getrost weitersuchen, weil die Sequenz kann ja nicht länger als 3 an dieser Stelle werden. (Das ganze gibt es als dynamischen Programmierungs-Algo, allerdings hab ich den speziellen Namen gerade nicht parat.)
 

Javinner

Top Contributor
Java:
public class SplitTheString
{

  
    public static void main(String[] args)
    {
        String zweiLeerZeichen = "- - -";
        System.out.println(leerzeichen(zweiLeerZeichen));
       
        String dreiLeerZeichen = " - - -";
        System.out.println(leerzeichen(dreiLeerZeichen));
       
        String vierLeerZeichen = "- - - - ";
        System.out.println(leerzeichen(vierLeerZeichen));
       
        String fuenfLeerZeichen = " - - - - ";
        System.out.println(leerzeichen(fuenfLeerZeichen));
    }

    public static int leerzeichen(String toCheck)
    {
        int x;
        String[] array = toCheck.split(" ");
        x = array.length;
        x = toCheck.charAt(toCheck.length() - 1) == ' ' ? (x):(x -= 1);
        return x;
    }

}
 

JCODA

Top Contributor
Ich finde, dass der Split sehr übersichtlich ist und eine Menge an Tipparbeit abnimmt. Wer die Klasse String kennt, sollte sich für ihre Methoden interessieren, vor allem als Anfänger :)
Natürlich. Programmierer sollten immer "das Rad nicht neu erfinden".

Man muss aber schauen, ob die Lösung das Problem tatsächlich löst:
Möchte man nur eine funktionierende Lösung oder eine performante. ( Insbesondere eine die, die Anforderung in der Aufgabenstellung erfüllt )
 

ocsme

Top Contributor
Danke erstmal :)
Ich mache die Sachen gerne selbst das ist meine Übung!
Klar ist es später besser die Methoden der String Klasse zu kennen und sowas dann darüber zu machen. Leider hatte ich bis jetzt noch nicht so sehr die Zeit mich damit auseinander zu setzen :D vielleicht liegt es auch daran das ich immer wieder alles selbst schreibe und so lange an den Aufgaben sitze :D

Javinner ist damit die Aufgabe erfüllt? Das mit dem Splitt verstehe ich nicht so wirklich :( wie schon gesagt werde ich mir wieder anschauen.
Ich hab ja eigentlich nur noch die Vergleiche benötigt die ich ja nun auch hin bekommen habe. So gesehen wird das Programm nicht schneller es ist ein "Pseudo Vergleich" da ich einen String oder gar ein String Array fülle mit leer Zeichen und diese mit dem gegebenen String vergleiche. Es wird nur dann schneller wenn mehr Leerzeichen drin sind als 1 denn dann habe ich ja 1 Vergleich weniger denn ich machen muss :D etc.!

Danke erstmal :)

LG
 

mihe7

Top Contributor
fülle mit leer Zeichen und diese mit dem gegebenen String vergleiche.
Bei der Aufgabe kommt es sehr darauf an, was man als "Vergleich" zählt. Ich würde sagen, dass damit jeder Vergleich eines Zeichens der Zeichenkette mit einem beliebigen Zeichen gemeint ist. In dem Fall hast Du sehr viele Vergleiche, weil Dein String-Vergleich ja selbst Zeichen miteinander vergleicht.

Ich werfe mal folgende Lösung in den Raum:
Java:
public class Test {
    private int max;
    private int vergleiche;
    private String str;
    private int len;

    public Test(String str) {
        this.str = str;
        this.len = str.length();
    }

    public void zaehle() {
        vergleiche = 0;
        max = 0;
        int lastNonSpace = -1;
        int i = 0;
        while (i < len) {
            if (isSpace(i)) {
                int bs = beginnSequenz(i, lastNonSpace);
                int es = endeSequenz(i+1);
                lastNonSpace = es;
                int sl = es - bs;
                max = Math.max(max, sl);
                i = es;
            } else {
                lastNonSpace=i;
            }         
            i += max + 1;
        }
    }

    private int beginnSequenz(int ix, int lastNonSpace) {
        while (ix > lastNonSpace+1 && isSpace(ix-1)) {
            ix--;
        }
        return ix;       
    }

    private int endeSequenz(int ix) {
        while (ix < len && isSpace(ix)) {
            ix++;
        }
        return ix;
    }

    private boolean isSpace(int ix) {
        vergleiche++;
        return str.charAt(ix) == ' ';
    }

    public static void main(String[] args) throws Exception {
        Test ws = new Test("AB     ABDEFGB C");
        ws.zaehle();
        System.out.printf("Maximale Länge: %d, Vergleiche %d\n", ws.max, ws.vergleiche);
    }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Eine Methode über Actionlistener beenden Java Basics - Anfänger-Themen 8
J Wert zurückgeben über get Methode Java Basics - Anfänger-Themen 8
H Methode über String Wert aufrufen Java Basics - Anfänger-Themen 8
CptK Interface Bild über Methode ändern funktioniert nicht Java Basics - Anfänger-Themen 4
J Aufruf einer Methode über einen String Java Basics - Anfänger-Themen 11
J Methode über Scanner aufrufen Java Basics - Anfänger-Themen 15
MiMa Datentyp Short Wert zuweisen über Methode Java Basics - Anfänger-Themen 2
D Werte von Variablen über Methode ändern Java Basics - Anfänger-Themen 10
F Problem bei eshop -> Ausführen einer Methode über eine Shopverwaltung Java Basics - Anfänger-Themen 6
M Wert von globalen Variablen über eine Methode ändern Java Basics - Anfänger-Themen 8
B Methoden Methode Direkt starten (über Kommandokonsole) Java Basics - Anfänger-Themen 5
R Fragen über Fragen, main-Methode und Co. Java Basics - Anfänger-Themen 32
D Methoden Methode über andere Klasse aufrufen Java Basics - Anfänger-Themen 7
I Nur main-Methode über Konsole aufrufbar? Java Basics - Anfänger-Themen 3
C Objekt X über Methode aus anderer Klasse verändert Java Basics - Anfänger-Themen 3
G Klasse überschreiben wenn Rückgabe über Methode Java Basics - Anfänger-Themen 6
U Frage über return Methode Java Basics - Anfänger-Themen 4
L Methode über for-schleife aufrufen und verändern Java Basics - Anfänger-Themen 7
L Methode über for-schleife aufrufen und verändern Java Basics - Anfänger-Themen 5
L ArrayList über Methode in Datei schreiben Java Basics - Anfänger-Themen 13
I Strukturfrage: Button über Methode erzeugen Java Basics - Anfänger-Themen 13
F Array deklarieren und über Methode aufrufen Java Basics - Anfänger-Themen 13
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
til237 Iterative Methode in rekursive Methode umschreiben Java Basics - Anfänger-Themen 4
M Daten aus errechneter Methode in Datenbank(SQLite) schreiben Java Basics - Anfänger-Themen 60
D next() Methode mehrfach verwenden Java Basics - Anfänger-Themen 1
Ostkreuz Methoden Von Dezimal zu Hexadezimal Methode toHex Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
N Throw an Main Methode übergeben Java Basics - Anfänger-Themen 7
M Methoden Methode 'wiederhole' nicht gefunden (Uebersetzungsfehler) Java Basics - Anfänger-Themen 1
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
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
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
M Anzahl Kommandozeilenparamter mittels Methode Java Basics - Anfänger-Themen 11
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
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
J Die statische Main-Methode ändert Instanzvariable? Java Basics - Anfänger-Themen 10
D Methode aus dem Aufrufer aufrufen Java Basics - Anfänger-Themen 1
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
U Beispiel Methode size() vom "Collection"-interface... Wie kann man sichtbar machen, was die Methode unter der Haube macht? Java Basics - Anfänger-Themen 8
D Warum kann ich hier nicht auf die Methode zugreifen? Java Basics - Anfänger-Themen 5
M generate Methode für Streams Java Basics - Anfänger-Themen 6
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
I Optionaler Parameter bei Methode, der nur optional ist? Java Basics - Anfänger-Themen 6
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
T Linked List set-Methode Java Basics - Anfänger-Themen 2
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
W Equals-Methode überschreiben bei composition Java Basics - Anfänger-Themen 20
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
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
V Methoden printChar Methode mit Rückgabetyp void Java Basics - Anfänger-Themen 26
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
berserkerdq2 wie funktioniert contenthandler, was muss ich bei der Methode startElement und endElement tun? Java Basics - Anfänger-Themen 11
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
S Methode Java Basics - Anfänger-Themen 4
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
Liroyd Methode mit Objektvariabel rechnen? Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
D Methode um mögliche Rezepte auszugeben Java Basics - Anfänger-Themen 12
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8
J Hallo zusammen , was macht diese Methode hier genau? Java Basics - Anfänger-Themen 3
D Array in Main Methode aus anderer Klasse aufrufen Java Basics - Anfänger-Themen 3
G jButton führt Main Methode nicht richtig aus Java Basics - Anfänger-Themen 3
G Main Methode wird beim ersten Aufruf nicht richtig ausgeführt Java Basics - Anfänger-Themen 1

Ähnliche Java Themen

Neue Themen


Oben