zeichen eines String mit der kleinsten Frequenz zurückgeben

bradig

Aktives Mitglied
Hallo,
ich habe ein kleines Problem.
Beim Testen habe ich festgestellt,dass meine Aufgabe nicht zu 100 prozent richtig ist.
ich weiß aber nicht,wo der Fehler liegt.

getCharacterWithMinimalFrequency("chhddajjekkb") gibt c statt a zurück.

a ist ja das kleinste Zeichnen mit der kleinsten Frequenz ,nicht c.
Bitte um Hilfe

Herzlich

Bradig


Java:
  /**
  * Gibt das Zeichen der gegebenen Zeichenkette zurück, dass am seltensten darin vorkommt.
  * Sollte es mehrere Zeichen mit minimaler Häufigkeit in der Zeichenkette geben, so wird
  * davon das Zeichen mit dem kleinsten Zahlenwert zurückgegeben
  * (Tipp: Zusammenhang char <-> int).
  * Falls es kein solches Zeichen gibt, wird eine {@link IllegalArgumentException} ausgelöst.
  *
  * Beispiel:
  * Gegeben die Zeichenkette "AABBCCabbccz"
  * Das gesuchte Ergebnis lautet hier: 'a'
  * (da 'a' genau wie 'z' nur einmal vorkommt, das 'a' aber einem kleineren Zahlenwert
  * als dem Zahlenwert von 'z' entspricht)
  *
  * @param input die Zeichenkette, deren Zeichen mit mininmaler Häufigkeit gesucht wird
  * @return das Zeichen mit dem kleinsten Zahlenwert, das am seltensten in der gegebenen
  * Zeichenkette vorkommt
  */
final public static char getCharacterWithMinimalFrequency(final String input) {
        if(input==null || input.length()==0){
            throw new IllegalArgumentException();
        }

        int min=Integer.MAX_VALUE;
        char c='0';
      
     
        for(int i=0;i<input.length();i++){
            int freq=getFrequency(input,input.charAt(i));
            if(freq<min ){
                min=freq;
                c=input.charAt(i);
               
            }
        }
        return c;

    }

    final public static int getFrequency(String input,char a){
        int s=0;
        for(int i=0;i<input.length();i++){
            if(input.charAt(i)==a){
                s++;
            }
        }
        return s;

    }
}
 

bradig

Aktives Mitglied
Java:
 final public static char getCharacterWithMinimalFrequency(final String input) {
        if(input==null || input.length()==0){
            throw new IllegalArgumentException();
        }

        int min=Integer.MAX_VALUE;
        char cMin=Character.MAX_VALUE;
      
     
        for(int i=0;i<input.length();i++){
            int freq=getFrequency(input,input.charAt(i));
            if(input.charAt(i)<cMin && freq<=min ){
                min=freq;
                cMin=input.charAt(i);
               
            }
        }
        return cMin;

    }

    final public static int getFrequency(String input,char a){
        int s=0;
        for(int i=0;i<input.length();i++){
            if(input.charAt(i)==a){
                s++;
            }
        }
        return s;

    }
funktioniert immer noch nicht
 

bradig

Aktives Mitglied
ich habe vieles ausprobiert ,aber es funktioniert immer noch nicht richtig.
hat noch irgendwer eine Ahnung ,wie ich mein Code verbessern kann,damit es richtig fünktioniert?

herzlich
 

mrBrown

Super-Moderator
Mitarbeiter
Ja, dein if passend umstellen.
Schreib einfach mal mit Worten auf, wann ein Buchstabe der mit der kleinsten Frequenz ist
 

Thallius

Top Contributor
Warum befolgst du nicht den Rat von Brown und schreibst es einfach mal auf. Dann sieht man es sofort.

Wenn die Frequenz kleiner ist als die alte minFreq oder die Frequenz = der alten minFreq und der neue Buchstabe kleiner als der alte minBuchstabe...
 

Cromewell

Top Contributor
Also, es gibt die Fälle:
- kleinere freq -> ändere min und cMin
- gleiche freq, und cMin kleiner -> ändere cMin (freq ist ja schon gleich)
Das musst du nur noch in Code "übersetzen".
 

bradig

Aktives Mitglied
es funktioniert jetzt .danke @Thallius und @mrBrown und @Cromewell

Java:
final public static char getCharacterWithMinimalFrequency(final String input) {
        if(input==null || input.length()==0){
            throw new IllegalArgumentException();
        }

        int min=Integer.MAX_VALUE;
        char c='0';

      
     
        for(int i=0;i<input.length();i++){
            int freq=getFrequency(input,input.charAt(i));
            if(freq<min){
                min=freq;
                c=input.charAt(i);
            }
            else if(freq==min &&input.charAt(i)<c){
                min=freq;
                c=input.charAt(i);
            }

        }
        return c;
    }

    final public static int getFrequency(String input,char a){
        int s=0;
        for(int i=0;i<input.length();i++){
            if(input.charAt(i)==a){
                s++;
            }
        }
        return s;

    }
 
Zuletzt bearbeitet:

bradig

Aktives Mitglied
es funktioniert auf jeden Fall schon.
kleine Frage:
weiß einer von euch wie man die NullPointerExceptions,die manchmal beim Testen auftreten , loswerden kann.
Beispiel:
if(a==null){
throw new IllegalArgumentException();
}
und beim Testen gebe ich folgendes ein :
methode(null) statt IllegalArgumentException zu bekommen ,bekomme ich NullPointerException.
 

mrBrown

Super-Moderator
Mitarbeiter
So völlig ohne Kontext kann man da nichts zu sagen.
Wenn das if als erster Teil der Methode steht, kann in der Methode aber keine NPE weil a null ist geworfen werden.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
G die ersten Zeichen eines Strings Vergleichen mit String Java Basics - Anfänger-Themen 6
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
G Teil(e) eines Strings entfernen wenn spezifische Zeichen (< & >) vorkommen Java Basics - Anfänger-Themen 5
N Bestimmte Zeichen eines Strings umwandeln Java Basics - Anfänger-Themen 4
T Auf jedes Zeichen eines Strings zugreifen? Java Basics - Anfänger-Themen 2
M Die letzten Zeichen eines Strings Java Basics - Anfänger-Themen 6
G Feststellen, ob erstes Zeichen eines Strings eine Ziffer ist Java Basics - Anfänger-Themen 11
G erstes Zeichen eines Strings herausfinden Java Basics - Anfänger-Themen 3
M Runden eines Doublewerts auf 13 Zeichen Java Basics - Anfänger-Themen 10
T Zeichen eines Strings an festgelegter Position einfügen Java Basics - Anfänger-Themen 8
B Zeichen eines Strings über Datei verteilen Java Basics - Anfänger-Themen 9
J Quelltext mit komischen griechischen Zeichen Java Basics - Anfänger-Themen 4
T or zeichen Java Basics - Anfänger-Themen 2
L 4 stelliges Passwort aus bestimmten Zeichen. Java Basics - Anfänger-Themen 27
R Größter zusammenhängender Block gleicher Zeichen im String Java Basics - Anfänger-Themen 1
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
I Eindeutiger String mit maximaler Anzahl an Zeichen Java Basics - Anfänger-Themen 11
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
O Array mit einem Zeichen vergleichen Java Basics - Anfänger-Themen 1
S Was bedeutet das Zeichen := Java Basics - Anfänger-Themen 9
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7
L Zeichen an bestimmter Stelle auslesen Java Basics - Anfänger-Themen 4
S Arrayausgabe und nur einmal ein Zeichen davor Java Basics - Anfänger-Themen 12
johnboyne Java Zeichen Trennen Java Basics - Anfänger-Themen 1
T Zeichen im String verschiebe Java Basics - Anfänger-Themen 17
Tino1993 for-Schleife, die eine vorgegebene Anzahl von Zeichen ausgibt Java Basics - Anfänger-Themen 3
pkm Regexproblem - Wie kann ich zwei oder mehr beliebige Zeichen matchen? Java Basics - Anfänger-Themen 7
Dimax Erste Schritte String replace alle Zeichen Java Basics - Anfänger-Themen 10
M Regex-Ausdruck: Alle Zeichen bis auf ein bestimmtes erlauben (p{L}) Java Basics - Anfänger-Themen 5
M Regex für bestimmte Wörter bzw. bestimmte Zeichen erstellen Java Basics - Anfänger-Themen 5
F RegEx "+" nur als Zeichen, nicht als Operator oder Sonstiges Java Basics - Anfänger-Themen 2
J Zeichen im String zählen Java Basics - Anfänger-Themen 3
J ObjectOutputStream writeChars, komische Zeichen nur in 1. Zeile Java Basics - Anfänger-Themen 2
H Fehlerausgabe (Ungewollte Zeichen) Java Basics - Anfänger-Themen 1
R Komische Zeichen in Java Java Basics - Anfänger-Themen 5
N Zeichen in einem Textfeld zählen und hinterlegen Java Basics - Anfänger-Themen 6
W Einfachen, ein beliebiges Zeichen oft erkennenden Regex Parser selber schreiben - wie vorgehen? Java Basics - Anfänger-Themen 12
J Vorkommen von Zeichen Java Basics - Anfänger-Themen 44
H Verschiebung von Zeichen Java Basics - Anfänger-Themen 18
O String von vorne nach hinten an einem Zeichen Java Basics - Anfänger-Themen 10
S char auf buchstabe/zeichen prüfen Java Basics - Anfänger-Themen 1
P Zeichenkette Zeichen ausschlißen funktioniert nicht richtig Java Basics - Anfänger-Themen 9
L String auf bestimmte zeichen untersuchen Java Basics - Anfänger-Themen 9
D gebe string zurück mit von bis bestimmtes Zeichen Java Basics - Anfänger-Themen 4
L Rekursion größtes Zeichen Java Basics - Anfänger-Themen 8
S Zeichen zählen kopierter Text Java Basics - Anfänger-Themen 6
Y String auf allgemein Zeichen untersuchen Java Basics - Anfänger-Themen 3
S String trennen nach beliebigen Zeichen Java Basics - Anfänger-Themen 3
C Zeichen im String bis zu bestimmter Stelle entfernen Java Basics - Anfänger-Themen 6
S Java Text splitten mit Tabs, Zeilen, Zeichen und Klammern. Java Basics - Anfänger-Themen 6
H Zeichen im algorithmus Java Basics - Anfänger-Themen 4
S Das Anführungszeichen(") Zeichen in einen String setzen Java Basics - Anfänger-Themen 1
G Zeichen suchen und Ausgeben. Java Basics - Anfänger-Themen 3
D Input/Output Split am Zeichen | Java Basics - Anfänger-Themen 2
m0n4ch Variablen String auf ungültige Zeichen überprüfen Java Basics - Anfänger-Themen 13
Voreck String Zeichen für Zeichen auslesen Java Basics - Anfänger-Themen 9
R Zeichen in String vergleichen Java Basics - Anfänger-Themen 75
G Gibt es eine Methode die bei einem StringBuilder n mal das Zeichen c hinzufügt? Java Basics - Anfänger-Themen 6
D String Zeichen für Zeichen auslesen Java Basics - Anfänger-Themen 5
S Zeichen ab Suchstring einlesen Java Basics - Anfänger-Themen 6
Z char Array unbekanntes Zeichen selbstständig anlegen Java Basics - Anfänger-Themen 6
M Pipe-Zeichen "|" in Java Java Basics - Anfänger-Themen 1
S Zeichen von abgerundeten Rechtecken auf einem Applet Java Basics - Anfänger-Themen 5
R Anzahl von Zeichen in einem Char Array Java Basics - Anfänger-Themen 4
F StringBuilder: Zeilenumbruch nach x Zeichen ohne Worttrennung Java Basics - Anfänger-Themen 1
F Zeichen einer Datei zaehlen Java Basics - Anfänger-Themen 1
D Java doppelte Zahl/Zeichen in einem String entfernen Java Basics - Anfänger-Themen 6
W JTextField-Objekt liest Umlaute mit falschen Zeichen ein Java Basics - Anfänger-Themen 5
G zeichen einer Zeile löschen Java Basics - Anfänger-Themen 4
M problem mit diesem zeichen | Java Basics - Anfänger-Themen 10
W char-Array auf bestimmte Zeichen prüfen Java Basics - Anfänger-Themen 10
B lanterna einzelne Zeichen aus dem Terminal löschen Java Basics - Anfänger-Themen 0
S Input/Output Alphabet in eine Datei schreiben und Anzahl von Zeichen ausgeben. Java Basics - Anfänger-Themen 4
C Anzahl bestimmter Zeichen in einem String ausgeben Java Basics - Anfänger-Themen 7
I String abschneiden erste und letzte Zeichen Java Basics - Anfänger-Themen 3
X Wann schreibt man diese Syntax zeichen { } Java Basics - Anfänger-Themen 8
S Leerzeichen zwischen zwei Zeichen im String entfernen Java Basics - Anfänger-Themen 19
F Methoden split() - Mehrere Zeichen Java Basics - Anfänger-Themen 5
M Input/Output Text auf Fenster zeichen Java Basics - Anfänger-Themen 2
F In einem String nach einem String suchen und Zeichen danach ausgeben Java Basics - Anfänger-Themen 6
S Kleines Zeichen berechnen Java Basics - Anfänger-Themen 5
Q Erste Schritte Zeichen in String farblich hervorheben Java Basics - Anfänger-Themen 4
U markierten Text auf Zeichen zuvor/danach pruefen Java Basics - Anfänger-Themen 9
M Input/Output Zeichen on Konsole einlesen Java Basics - Anfänger-Themen 3
DStrohma Operatoren Kleiner-Zeichen in Größer-Zeichen ändern wenn boolen true? Java Basics - Anfänger-Themen 6
G Input/Output Verhalten BuffferedReader bei unvollständigen Zeichen Java Basics - Anfänger-Themen 1
P String Zeichen zuweisen Java Basics - Anfänger-Themen 3
Q Erste Schritte In CharArrayWriter Zeichen an Stelle einfügen Java Basics - Anfänger-Themen 4
H Programm zum Zählen von Zeichen Java Basics - Anfänger-Themen 5
P Methode die String auf Zeichen überprüft Java Basics - Anfänger-Themen 2
A Seltsame Zeichen vor Clienteingabe Java Basics - Anfänger-Themen 5
M Prüfen, ob Zeichen eine Zahl ist Java Basics - Anfänger-Themen 3
T Wörter mit @ als Zeichen finden Java Basics - Anfänger-Themen 13
E Zeichen von Kommandozeilenparameter zählen Java Basics - Anfänger-Themen 6
W String von hinten alle drei Zeichen abschneiden und in umgekehrter Reihenfolge ausgeben. Java Basics - Anfänger-Themen 9
J String Ausgabe nicht-leerer Zeichen nicht korrekt Java Basics - Anfänger-Themen 10
H JEditorPane: ermitteln, ob Zeichen unterstrichen Java Basics - Anfänger-Themen 4
I Zeichen aus String ziehen Java Basics - Anfänger-Themen 3
X Klassen mit Suffix hinter @-Zeichen Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben