Veröffentlicht 14. November 200915 j 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?
14. November 200915 j In der Zeile darfst du value nicht mit [] schreiben. Du willst ja nicht nur eine Element, sondernd as ganze Array übergeben. Grüße, JasonDelife.
14. November 200915 j 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:
15. November 200915 j 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.
16. November 200915 j 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 200915 j von speedi
16. November 200915 j 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())
Erstelle ein Konto oder melde dich an, um einen Kommentar zu schreiben.