bec53167 Geschrieben 14. November 2009 Teilen Geschrieben 14. November 2009 Hi ich ich komme bei einer Methode einfach nicht weiter, in der es darum geht einen String umzudrehen. Also z.B. aus REGAL wird LAGER. public String umDrehen(String s) { if ((s.length() == 0) || (s.length() == 1)) { System.out.println("Fehler"); return null; } else { int max = s.charAt(s.length() - 1); char[] value = new char[max]; for(int i = 0; i< max; i++) { value[max-i] = s.charAt(max - (i+1)); } char last = value[0]; for( int i= 0; i < max; i++) { value[0+i] = value[max-i]; } String name = new String(value[]); // Fehler: .class expected return name; } } Hat jemand ne AHnung was der Fehler ist? Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
JasonDelife Geschrieben 14. November 2009 Teilen Geschrieben 14. November 2009 In der Zeile darfst du value nicht mit [] schreiben. Du willst ja nicht nur eine Element, sondernd as ganze Array übergeben. Grüße, JasonDelife. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
bec53167 Geschrieben 14. November 2009 Autor Teilen Geschrieben 14. November 2009 Danke, jetzt lässt such die Klasse fehlerfrei übersetzten. Aber wenn ich die Methode ausführe bekomme ich eine Fehlermeldung: public String umDrehen(String s) { if ((s.length() == 0) || (s.length() == 1)) { System.out.println("Fehler"); return null; } else { int max = s.charAt(s.length() - 1); char[] value = new char[max]; for(int i = 0; i< max; i++) { value[max-i] = s.charAt(max - (i+1)); } char last = value[0]; for( int i= 0; i < max; i++) { value[0+i] = value[max-i]; } String name = new String(value); return name; } } folgender Fehler tritt auf: :confused: Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
MartinSt Geschrieben 15. November 2009 Teilen Geschrieben 15. November 2009 warum so kompliziert? Lass doch einfach in der 1. for-Schleife den Zähler abwärts laufen, so dass s von hinten nach vor durchlaufen wird und hänge direkt in dieser for-Schleife jedes gefundene Zeichen an den Ergenbisstring an. Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
speedi Geschrieben 16. November 2009 Teilen Geschrieben 16. November 2009 (bearbeitet) Kein Wunder, dass der fehler auftritt. Dein Max ist ja am anfang nicht die Länge des Strings sondern der Wert des letzten chars im String. Ein char ist im prinzip auch nichts anderes wie eine Zahl. Nur wird dieser dann anhand einer Zeichensatz-Tabelle ein bestimmtes Zeichen zugeordnet. Du kannst mit chars sogar rechnen und genau das tust du auch - wenn auch eher unbeabsichtigt. Wenn du z.B. "Hallo" eingeben würdest wäre max dann (int)'o' (irgendwo zwischen 70 und 100). Das ist natürlich schmarrn. Sinvoller wäre bestimmt 4. Setz max auf s.lenght- 1 !!OHNE!! charAt(). Bearbeitet 16. November 2009 von speedi Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
ksg9-sebastian Geschrieben 16. November 2009 Teilen Geschrieben 16. November 2009 Variante 1: char[] str = myString.toCharArray(); char[] newStr = new char[str.length]; int count = 0; for(int i=arr.length-1; i>=0; i--){ newStr[count++] = str[i]; } oder für die ganz faulen: // myString ist der String den du umdrehen willst char[] strReverse = (char[]) Collections.reverse(Arrays.asList(myString.toCharArray())).toArray(new Character[strArray.length]); Variante 2 tut so: - String in char-Array umwandeln (Arrays.asList()) - Liste umdrehen (Collections.reverse()) - Liste in Array umwandeln (.toArray()) Zitieren Link zu diesem Kommentar Auf anderen Seiten teilen Mehr Optionen zum Teilen...
Empfohlene Beiträge
Dein Kommentar
Du kannst jetzt schreiben und Dich später registrieren. Wenn Du ein Konto hast, melde Dich jetzt an, um unter Deinem Benutzernamen zu schreiben.