String auf Pallindromeigenschaft prüfen

Schwupsi

Aktives Mitglied
Hallo Java Forum,
ich weiß, ich hab schon die SuFu genutzt, aber das hat mir nicht so richtig weitergeholfen.

Wir müssen ein Programm erstellen, welches einen beliebigen String darauf prüft, ob es ein Pallindrom ist oder nicht.

Habe mir schon einige Gedanken gemacht und folgender Code kam dabei raus:


Java:
	public static void main(String[] args) {
		String wort = "lagerregal";
		// String wort = "deutschland";
		// str.length() - Stringlänge
		// str.charAt(pos) - bestimmter Buchstabe auf Position pos
		

                boolean palli = true;

		int n; // für Stringlänge
		n = wort.length() - 1;
		int k = 0;

		for (int i = 0; i <= n; i++) 
			if (wort.charAt(k) == wort.charAt(n)) {
				palli = true;
			} else {
				palli = false;
				
			}
			k++;
			n--;

		

		if (palli)
			System.out.println("'" + wort + "' ist ein Palindrom.");
		else
			System.out.println("'" + wort + "' ist kein Palindrom.");
	}
}


Wie ihr seht, funktioniert das Programm noch nicht so richtig. Ich hab den Algo im Kopf, aber weiß nicht wie ich ihn als Code umsetzen soll. Ich will zwei Variablen setzen, eine die den ersten Buchstaben quasi nimmt und eine die den letzten nimmt, anschließend erfolgt durch ein if der Vergleich beider Buchstaben, kommt true raus, gehts weiter -> die eine Variable ++ die andere --

Bin aber total durcheinander, bin dankbar für hilfreiche Tipps.

MfG
 
Zuletzt bearbeitet von einem Moderator:

Androbin

Bekanntes Mitglied
Das 1. Problem ist, dass du in Zeile 16 palli = true setzt! ==> Einfach löschen!
Das 2. Problem ist, dass du du In-/De-krementierung von k und n nicht mit in der for-Schleife hast!
PS. Du solltest palli als Bedingung in die for-Schleife einbauen, um Zeit zu sparen!

Java:
public static void main( String[] args ) {
	
	String wort = "lagerregal";
	
	boolean palli = true;
	
	for ( int i = 0; i < wort.length() && palli; i++ ) 
		if ( wort.charAt( i ) != wort.charAt( wort.length() - i - 1 ) ) {
			palli = false;
	
	if ( palli ) System.out.println( "'" + wort + "' ist ein Palindrom." );
	else System.out.println( "'" + wort + "' ist kein Palindrom." );
	
}
 
Zuletzt bearbeitet:

Flown

Administrator
Mitarbeiter
Ich würde noch eine Optimierung hinzufügen und nur bis zur Mitte des Strings laufen:

Java:
public class Palindrom {
  
  public static void main(String[] args) {
    System.out.println(isPalindrom("Reliefpfeiler"));
    System.out.println(isPalindrom("maoam"));
    System.out.println(isPalindrom("test"));
  }
  
  public static boolean isPalindrom(String s) {
    int length = s.length();
    char[] charArray = s.toCharArray();
    for (int i = 0; i < length / 2; i++) {
      if (Character.toLowerCase(charArray[i]) != Character.toLowerCase(charArray[length - i - 1])) {
        return false;
      }
    }
    return true;
  }
  
}
 
Zuletzt bearbeitet:

Schwupsi

Aktives Mitglied
Okay, der Code ist für mich auf den ersten Blick sehr verständlich.

Zum Verständnis: Wenn die for-Schleife anfängt ist i bei 0. Das heißt das Programm pickt sich erstmal den Buchstaben an der Stelle 0, also "L" raus. Dann schaut das Programm ob "L" ungleich mit dem Buchstaben an der Position 10-0-1 =9 also "L".
Bedingung wird nicht erfüllt, da gleich, also i++ und von neuem. Buchstabe an der Stelle 1 ("A") mit Buchstabe an der Stelle 10-1-1=8 ("A"). Und so weiter.

Aber wenn ich es ausführen will funktioniert das Programm nicht, für mich sieht es so schon funktionsfähig aus.

MfG
 

Flown

Administrator
Mitarbeiter
Androbin hat dir doch schon die Lösung gepostet, aber wenn du deinen Code nochmals haben willst mit In- und Dekrement.

Java:
public class Palindrom {
  
  public static void main(String[] args) {
    System.out.println(isPalindrom("Reliefpfeiler"));
    System.out.println(isPalindrom("maoam"));
    System.out.println(isPalindrom("test"));
    System.out.println(isPalindrom(""));
  }
  
  public static boolean isPalindrom(String s) {
    for (int i = 0, j = s.length() - 1; i <= j; i++, j--) {
      if (Character.toLowerCase(s.charAt(i)) != Character.toLowerCase(s.charAt(j))) {
        return false;
      }
    }
    return true;
  }
}
 

Schwupsi

Aktives Mitglied
Danke für deinen Code, aber der bringt mir nicht viel, da wir Sachen wie "Character.toLowerCase", "return" oder ähnliches noch nicht besprochen haben und dementsprechend nicht benutzen dürfen. Da schaut Androbins Code etwas anfängerfreundlicher aus, jedoch kommt beim Ausführen des Codes nichts raus, nur blank. Aber der Code sieht für mich so aus, dass er funktionieren müsste.
 

Flown

Administrator
Mitarbeiter
Ok zur Erklärung dein Programm funktioniert nur wenn alles klein oder groß geschrieben ist, d.h. "mAoaM" wäre bei dir kein Palindrom, obwohl es eines ist, darum wird hier der char an der Stelle i in Kleinbuchstaben umgewandelt. Ich habe isPalindrom in eine Methode ausgelagert, damit ich sie öfters aufrufen kann. Diese Methode hat einen Rückgabewert vom Typ boolean. Da die Methode etwas zurückgeben muss, gibt es das Schlüsselwort "return". Es hat auch noch den Vorteil, dass es die Methode sofort verlässt, wenn man ein return Statement einfügt.

Nochmal zu deinem Programm:

Java:
public class Palindrom {
  public static void main(String[] args) {
    // String wort = "lagerregal";
    // String wort = "deutschland";
    String wort = "reliefpfeiler";
    
    boolean palli = true;
    
    int i = 0;
    int j = wort.length() - 1;
    while (i <= j && palli) {
      if (wort.charAt(i) != wort.charAt(j)) {
        palli = false;
      }
      i++;
      j--;
    }
    
    if (palli) {
      System.out.println("'" + wort + "' ist ein Palindrom.");
    } else {
      System.out.println("'" + wort + "' ist kein Palindrom.");
    }
  }
}

Jetzt hier ohne Methoden und unnötigen Anweisungen.
 

Schwupsi

Aktives Mitglied
Danke für deine Mühe, Flown!

Aber ich habe herausgefunden wieso der vorherige Code nur blank ausgab. bei dem if (palli) am Ende des Codes habe ich stattdessen eingegeben "if (palli==true)", dann gings.

Danke nochmal an alle, die Antworten waren sehr hilfreich :)
 

Flown

Administrator
Mitarbeiter
Ich will dir ja keine Illusionen nehmen aber:
Java:
if(pali) {}
ist genau das gleiche wie
Java:
if(pali==true){}
 

Schwupsi

Aktives Mitglied
Hast Recht! Ging aber aus irgendeinem Grund trotzdem nicht :D

Eine andere Frage:
Ich soll die Häufigkeiten von zufällig ausgegebenen Noten bestimmen und ausgeben. Habe hier einen Code der funktioniert, aber eben ab einer bestimmten n zu lang würde.

Java:
		int[] hauef = new int[5];

		
		int note;
		for (int i = 1; i <= 100; i++) {
			
			note = (int) (Math.random() * 5 + 1);

			
			if (note == 1)
				hauef[0]++;
			if (note == 2)
				hauef[1]++;
			if (note == 3)
				hauef[2]++;
			if (note == 4)
				hauef[3]++;
			if (note == 5)
				hauef[4]++;
		}

Wie kann ich diese if's in einer for-Schleife automatisieren quasi, damit es auch für gröeßere Spannen funktioniert und ich nicht n Zeilen if's schreiben muss.

Danke
 

Schwupsi

Aktives Mitglied
Habe eine weitere Frage, hier wird so toll geholfen :D

Ein Algorithmus zur Berechnung der Quersumme einer beliebigen Zahl, alles schön und gut der Code klappt auch. Was ich aber nicht verstehe, wieso muss bei der Methode int a deklariert werden, obwohl die Variable nicht genutzt wird? Ohne gehts nicht.

Java:
	private static int querSumme([B]int a[/B]) {
		int zahl = 6947859;
		int querSumme = 0;
		while (zahl > 0) {
			querSumme = querSumme + zahl % 10;
			zahl = zahl / 10;

		}
		return querSumme;

	}
 

njans

Top Contributor
Ich werde es trotzdem mal schnell beantworten: Es muss nicht deklariert werden.
Wenn du da von deiner IDE gesagt bekommst, dass es das muss, dann wird die Methode entweder vererbt, durch ein Interface vorgeschrieben oder wird irgendwo mit einem Parameter aufgerufen, so dass die IDE das angleichen will.
 

Schwupsi

Aktives Mitglied
Danke njans! Jetzt ist hier aber endgültig zu! :D

Werde mich dann sicherlich noch in separaten Threads nochmal melden und um Rat fragen.

Danke nochmal an alle! :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
E String zerlegen aus args Java Basics - Anfänger-Themen 1
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
I Zerlegen von String Java Basics - Anfänger-Themen 3
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
M String beim einlesen formatieren Java Basics - Anfänger-Themen 12
N null in String replacen Java Basics - Anfänger-Themen 16
R Compiler-Fehler JTable mit XML befüllen | The constructor JTable(Object[], String[]) is undefined Java Basics - Anfänger-Themen 10
M Eclipse kennt keine String Klasse mehr Java Basics - Anfänger-Themen 1
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
D String mit int multiplizieren? Java Basics - Anfänger-Themen 16
H Überprüfen ob String Array leer ist Java Basics - Anfänger-Themen 4
A Korrigierte <String> Liste zurückgeben Java Basics - Anfänger-Themen 22
C In String, Buchstaben ersetzen durch andere Buchstaben Java Basics - Anfänger-Themen 26
Poppigescorn String mit mehreren Wörtern füllen? Java Basics - Anfänger-Themen 4
I String Expression mit Java validieren (true / false) Java Basics - Anfänger-Themen 34
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
T Maximale Anzahl von Konsonanten im String Java Basics - Anfänger-Themen 6
H String verschlüsseln - eigener Algorithmus Java Basics - Anfänger-Themen 104
N Aus einem String die Anzahl der Vokale auslesen Java Basics - Anfänger-Themen 40
J Eintrag Combobox über einen String auswählen Java Basics - Anfänger-Themen 3
K mit String.splitt(",") ganzen Satz erhalten? Java Basics - Anfänger-Themen 3
K Wie String prüfen ob drei mal das gleiche Zeichen vorkommt? Java Basics - Anfänger-Themen 7
I Validation, ob String ein Wert aus einem Enum enthält Java Basics - Anfänger-Themen 3
D String und char in String speichern Java Basics - Anfänger-Themen 5
A ObservableList<String> Java Basics - Anfänger-Themen 6
I String nach Wort suchen Java Basics - Anfänger-Themen 6
I String ersetzen, der Inhalt enthält Java Basics - Anfänger-Themen 4
L ArrayList<String> --> double[] array Java Basics - Anfänger-Themen 18

Ähnliche Java Themen

Neue Themen


Oben