Palindrom Programm

HeroYui

Neues Mitglied
Hey ich habe ein Program geschrieben welches die größte Palindromzahl[z.B. 101] sucht welche aus 2 3-stelligen Zahlen erzeugt wird. Aus einem mir unerfindlichen Grund ist die ausgabe des Programmes jedoch nur die das größte palindrom 0 seie. Könntet ihr mir bitte sagen aus welchem grund dieses Ergebnis erschein? Danke!
Java:
package programme;

public class EulerP4 {
	public static void main(String[] args) {
	int k = 999;
	int l = 999;
	int z = 0;
	int u = 0;
	if (l != 0){
		z = (k * l);
		k --;
		if (k == 1){
			k = 999;
			l --;
		}
		String p1 = String.valueOf(z);
			if (isPalindrom(p1)){
				if (z>u){
					u = z;
				}
	
		}
	}
	System.out.println("Die größte Palindromische Zahl aus 2 3-Stelligen Zahlen ist: " + u);
	}
    public static boolean isPalindrom(String input)
    {
        return new StringBuffer(input.replaceAll("\\s","")).reverse().toString().equalsIgnoreCase(input.replaceAll("\\W",""));
    }
}
 
Zuletzt bearbeitet:

pl4gu33

Top Contributor
dieser Teil wird in deinem Beispiel nicht aufgerufen,... daher bleibt u = 0

Java:
if (isPalindrom(p1)){  //Bedingung nicht erfüllt
 if (z>u){
     u = z;
}
 

Flown

Administrator
Mitarbeiter
Da fehlt irgendwie eine Schleife drum herum, wenn du das Maximum ermitteln willst.

[EDIT]Achtung Spoiler: [/EDIT]

Java:
public class PalindromTest {

	public static void main(String[] args) {
		
		int k = 999;
		int l = 999;

		PalindromTest t = new PalindromTest();
		System.out.println("Das größte Palindrom ist: " +t.highestPalindrom(k, l));
	}
	
	public int highestPalindrom(int k, int l) {
		if((k/100 <= 0 || k/1000 > 0)|| (l/100 <= 0 || l/1000 > 0)) {
			throw new IllegalArgumentException("Argumente müssen 3-stellig sein.");			
		}
		
		for(int i = k*l; i >= 0; i--) {
			if(isPalindrom(i)) return i;
		}
		
		return 0;
	}
	
	private boolean isPalindrom(int p){
		return new StringBuffer(String.valueOf(p).replaceAll("\\s","")).reverse().toString().equalsIgnoreCase(String.valueOf(p).replaceAll("\\W",""));
	}
	
}
 
Zuletzt bearbeitet:

Claudia92

Mitglied
@Flown: Deinem Programm nach wäre das höchste sich aus zwei dreistelligen Faktoren zusammensetzende Palindrom 997799. Dass das ein Palindrom ist, sieht man. Aber es setzt sich leider nicht aus zwei dreistelligen Faktoren zusammen, denn 997799 = 11 * 90709.

Java:
        for(int i = k*l; i >= 0; i--) {
            if(isPalindrom(i)) return i;
        }
Du fängst zwar mit i = k*l an, aber sobald du i-- machst, ist nicht mehr sicher, dass es ganzzahlige k, l gibt, für die i = k*l gelten würde. ;)
 

HeroYui

Neues Mitglied
Danke für die Hilfe, gelöst habe ich es nun in dem ich einfach das 1. if durch ein for austauschte.
[JAVA=9]if (l != 0){[/code]
Wurde also ersetzt durch
[JAVA=9]for (;l != 0; k--){[/code]
und um Code zu sparen wurde die Ursprüngliche z.11 gelöscht da diese in dem for enthalten ist. Der Finale code sieht also folglich so aus:
Java:
package programme;
public class EulerP4 {
	public static void main(String[] args) {
	int k = 999;
	int l = 999;
	int z = 0;
	int u = 0;
	for (;l != 0; k--){
		z = (k * l);
		if (k == 1){
			k = 999;
			l --;
		}
		String p1 = String.valueOf(z);
			if (isPalindrom(p1)){
				if (z>u){
					u = z;
				}
		}
	}
	System.out.println("Die größte Palindromische Zahl aus 2 3-Stelligen Zahlen ist: " + u);
	}
    public static boolean isPalindrom(String input)
    {
        return new StringBuffer(input.replaceAll("\\s","")).reverse().toString().equalsIgnoreCase(input.replaceAll("\\s",""));
    }
}
 
H

hüteüberhüte

Gast
Code:
Die größte Palindromische Zahl aus 2 3-Stelligen Zahlen ist:
kann mir das jemand erklären, was damit gemeint ist? Alle Kombinationen aus zwei Zahlen, die ohne vorangestellte Ziffern jeweils aus drei Ziffern bestehen? Dann würden doch alle gleichen Zahlen schon mal ein Palindrom bilden, und die höchste Zahl wäre 999 999. Was gibts da noch zu testen?
 

AquaBall

Top Contributor
Code:
Die größte Palindromische Zahl aus 2 3-Stelligen Zahlen ist:
kann mir das jemand erklären, was damit gemeint ist? Alle Kombinationen aus zwei Zahlen, die ohne vorangestellte Ziffern jeweils aus drei Ziffern bestehen? Dann würden doch alle gleichen Zahlen schon mal ein Palindrom bilden, und höchste Zahl wäre 999 999. Was muss man da noch testen?

Aus;
Java:
        z = (k * l);
schließe ich, dass mit "aus 2 3-Stelligen Zahlen" gemeint ist "ein Produkt aus 2 3-stelligen Zahlen".
 
H

hüteüberhüte

Gast
Ok, es gibt (999-99)^2 solcher Produkte. Sollte ja nicht all zu schwer sein, die zu berechnen

Einige Zahlen lassen sich sicher auch überspringen

String.valueOf ist doch unnötig aufwändig?
 

Claudia92

Mitglied
@hüteüberhüte: Dann lass uns doch wissen, wie du es gemacht hättest! ;)

Meine Lösung sieht so aus:
Java:
	static int p4(int n) {
		int maxPalindrome = 0;
		n = (int) (Math.pow(10, n)-1);
		for (int i = n; i*i > maxPalindrome; i--)
			for (int j = i; j*j > maxPalindrome; j--)
				if (isPalindrome(String.valueOf(i*j)) && i*j > maxPalindrome)
						maxPalindrome = i*j;
		return maxPalindrome;
	}
	
	static boolean isPalindrome(String s) {
		return new StringBuilder(s).reverse().toString().equalsIgnoreCase(s);
	}
Der Parameter n gibt die maximale Anzahl an Stellen der beiden Faktoren an.

Wieso meinst du, String.valueOf sei unnötig aufwändig? Über einen StringBuilder lässt sich meiner Meinung nach am elegantesten prüfen, ob eine Zahl ein Palindrom ist. Ich lasse mich aber gerne eines Besseren belehren. ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
sserio Größtes Palindrom-Produkt Programm funktioniert nur halb Java Basics - Anfänger-Themen 23
P Programm Hilfe Palindrom Java Basics - Anfänger-Themen 6
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
A Palindrom Java Basics - Anfänger-Themen 3
H Palindrom ermitteln Java Basics - Anfänger-Themen 21
N palindrom erkennen Java Basics - Anfänger-Themen 3
H Harshad-Zahl (Nivenzahl) und Palindrom überprüfen Java Basics - Anfänger-Themen 2
L Palindrom in zweidimensionalem Array Java Basics - Anfänger-Themen 16
B Palindrom Test mit Junit Java Basics - Anfänger-Themen 23
T Auf Palindrom überprüfen Java Basics - Anfänger-Themen 10
R Best Practice Palindrom in einem Text finden Java Basics - Anfänger-Themen 18
L In Javakara Palindrom erkennen. Java Basics - Anfänger-Themen 9
C Bei der LinkedList auf Palindrom überprüfen Java Basics - Anfänger-Themen 4
Y Rekursiv Palindrom herausfinden Java Basics - Anfänger-Themen 5
C Palindrom im array Java Basics - Anfänger-Themen 5
R Palindrom eines int-Arrays berechnen Java Basics - Anfänger-Themen 14
D Palindrom Java Basics - Anfänger-Themen 15
K Palindrom Test Java Basics - Anfänger-Themen 9
C Überprüfen auf Palindrom Java Basics - Anfänger-Themen 12
P Palindrom Java Basics - Anfänger-Themen 10
R In einem Palindrom 2 Buchstaben vergleichen Java Basics - Anfänger-Themen 16
H Palindrom Java Basics - Anfänger-Themen 7
NoXiD Auf Palindrom Prüfen Java Basics - Anfänger-Themen 9
M Palindrom mit Groß & kleinbuchstaben Java Basics - Anfänger-Themen 19
M Palindrom Test mit Char-arrays! Java Basics - Anfänger-Themen 3
A "Hello World"-Programm läuft nicht Java Basics - Anfänger-Themen 16
J Delay erzeugen, ohne Programm zu blockieren Java Basics - Anfänger-Themen 7
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
M Java Mail Programm Java Basics - Anfänger-Themen 4
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
M Mini Jar-Programm Java Basics - Anfänger-Themen 51
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
M Das Programm stellt nichts dar Java Basics - Anfänger-Themen 2
K Programm compilierbar aber nicht ausführbar... Java Basics - Anfänger-Themen 21
Z Programm Ideen Java Basics - Anfänger-Themen 8
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
T Programm stürzt ab Java Basics - Anfänger-Themen 40
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
N Programm Funktioniert mit .txt Datei aber nicht mit .rtf Datei Java Basics - Anfänger-Themen 2
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
Jul1n4tor Programm mit Scanner und If-Statements Java Basics - Anfänger-Themen 2
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
K Ist das Programm schlecht bzw. schlampig programmiert ? Java Basics - Anfänger-Themen 9
Zrebna Kann Java Programm nicht in Konsole ausführen Java Basics - Anfänger-Themen 1
K Warum läuft das Programm nicht(bzw. nicht richtig) Java Basics - Anfänger-Themen 4
M Von Eclipse zum richtigen Programm Java Basics - Anfänger-Themen 1
nbergmann IntelliJ: Wie lade ich ein fertiges Programm aus dem Lehrbuch? Java Basics - Anfänger-Themen 26
D Anfängerfrage zu meinem Programm. Java Basics - Anfänger-Themen 15
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 22
I Jetty starten von Programm (Main) Java Basics - Anfänger-Themen 27
Kydo Programm Beschreibung Java Basics - Anfänger-Themen 3
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 7
T Java FXML selbes Fenster verschiedene Stellen im Programm Java Basics - Anfänger-Themen 5
frager2345 Programm erstellen ohne Autoboxing und Unboxing Java Basics - Anfänger-Themen 13
D JAVA Programm schreiben Java Basics - Anfänger-Themen 46
P exportiertes Programm funktioniert nur teilweise Java Basics - Anfänger-Themen 7
J Mein Programm läuft bei der ersten Eingabe nicht mehr weiter, woran liegt das? Java Basics - Anfänger-Themen 6
M Wo hält das Programm an? Java Basics - Anfänger-Themen 11
J Mein Java Programm lässt sich nicht mehr bearbeiten Java Basics - Anfänger-Themen 2
Fugover Programm funktioniert nicht Java Basics - Anfänger-Themen 11
Fugover Kopfrechnen-Programm Java Basics - Anfänger-Themen 6
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
sserio Wieso funktioniert mein Programm nicht Java Basics - Anfänger-Themen 2
J selbst erstellte Datei mit Programm öffnen Java Basics - Anfänger-Themen 10
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
A wie kann ich es in meinem Programm rein tun Java Basics - Anfänger-Themen 8
S Fehler beim Programm Java Basics - Anfänger-Themen 2
Jose05 Fehler im Programm feststellen Java Basics - Anfänger-Themen 2
F Kann mir jemand kurz dieses Programm erklären? Java Basics - Anfänger-Themen 22
I Programm erkennt nicht an das Array zurückgegeben wird trotz Initialisierung *einfach* Java Basics - Anfänger-Themen 9
J Nach dem Exportieren funktioniert mein Programm nicht mehr Java Basics - Anfänger-Themen 8
P Mein Programm wird zwar erfolgreich Compiliert, öffnet sich aber nicht Java Basics - Anfänger-Themen 6
J Kann ich mein Programm so schreiben? Java Basics - Anfänger-Themen 4
A Lotto Programm Java Basics - Anfänger-Themen 3
S Programm erstellen Java Basics - Anfänger-Themen 3
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
S MinMax Programm erstellen Java Basics - Anfänger-Themen 4
J Interpreter-Fehler Programm gibt nicht gewünschtes Ergebnis aus Java Basics - Anfänger-Themen 11
brypa Programm mit Eingabe Java Basics - Anfänger-Themen 129
B Java Programm soll mit Python kommunizeren Java Basics - Anfänger-Themen 1
SpigBin Programm läuft nicht weiter... Java Basics - Anfänger-Themen 10
M JAVA Programm in Website einbinden Java Basics - Anfänger-Themen 19
B Programm, dass alle 3 Tage eine Webseite öffnet? Java Basics - Anfänger-Themen 20
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
N Eclipse Programm normal ausführen Java Basics - Anfänger-Themen 1
D Programm auf Enter warten lassen Java Basics - Anfänger-Themen 2
C Programm das feststellen kann, ob eine eingegebene Zahl einem Schaltjahr entspricht, richtig geschrieben? Java Basics - Anfänger-Themen 11
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
WAB9703-04 Programm zum automatischen Ausfüllen von Formularen programmieren Java Basics - Anfänger-Themen 3
OSchriever Jar-Programm läuft auf Windows aber nicht auf Linux(Raspberri Pi4) Java Basics - Anfänger-Themen 22
G Programm Code Java Basics - Anfänger-Themen 5
CptK Achsenskalierung in Koordinatensystem hängt Programm auf Java Basics - Anfänger-Themen 5

Ähnliche Java Themen

Neue Themen


Oben