Palindrom eines int-Arrays berechnen

Rauschkugel

Mitglied
Hi, ich möchte von einem int-Array dessen Palindrom ausgeben lassen und hab dazu folgendes programmiert. Kann mir jmd helfen, wieso ich [7,7,7,7,7] ausgegeben bekomme? Wo liegt der Fehler in meinem Programm?


Java:
public class Test {
	
	//Methode zur Berechnung des Palindroms
	public static int[] palindrom(int[] a){
		int[] hilfsarray = new int[a.length];
		for (int i=0; i<a.length; i++){
			for (int j=a.length-1; j>=0; j--){
			hilfsarray[i] = a[j];
			}
		}
		return hilfsarray;
}
	
	//Methode für die Ausgabe des Arrays
	public static void printArray(int[] a) {
        if (a.length == 0) {
            return;
        }
        System.out.print("[");
        for (int i = 0; i < a.length; i++) {
            System.out.print(a[i]);
            if (i != a.length - 1) {
                System.out.print(",");
            }
        }
        System.out.println("]");
    }

	
	//main-Methode
	public static void main(String[] args) {
		System.out.print("palindrom(7,4,8,42,13) = ");
		printArray(palindrom(new int[]{7, 4, 8, 42, 13})); 
    }
}
 

minzee

Bekanntes Mitglied
Das liegt an deiner Schleife in der Schleife. Mit j bewegst du dich immer zum ersten Element, der 7. Die schreibst du in das Element i. Und das i läuft von links nach rechts durch. Darum bekommst du das erste Element genau so oft, wie lange das Array ist.

Was willst du hier eigentlich berechnen? Ist eine UNI-Aufgabe, richtig? Könnten wir die Aufgabe lesen?
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Java:
class Main
{
   static private int[] createPalindrom(int[] a)
   {
      int aLength = a.length;
      if(aLength < 2)
      {
         return a;
      }
      int bLength = 2 * aLength - 1;
      int[] b = new int[bLength];
      for(int i = 0; i < aLength; ++i)
      {
         b[bLength - i - 1] = b[i] = a[i];
      }
      return b;
   }
   public static void main(String[] args)
   {
      int[] a = {7, 4, 8, 42, 13};
      int[] b = createPalindrom(a); 
      for(int i = 0; i < b.length; ++i)
      {
         System.out.println(b[i]); // 7 4 8 42 13 42 8 4 7
      }
   }
}
Suchst du das hier?
 

njans

Top Contributor
Kleiner Tipp: Du brauchst nur eine Schleife.
Um die Reihenfolge deines Arrays umzudrehen, musst du nur den index neu berechnen.
Dazu machst du folgendes:
index_0 ---> index_length-1
index_1 ---> index_length-2
index_2 ---> index_length-3
usw.

Das geht einfach zu lösen und ist eine Zeile.

@minzee
Nicht immer Lösungen herausgeben!
Und ich glaube er will nur die Reihenfolge seines Arrays umdrehen
 
Zuletzt bearbeitet:

Rauschkugel

Mitglied
Also die Aufgabe lautet: Berechnen Sie für ein int-Array dessen Palindrom, das heißt das Array in umgekehrter Reihenfolge.
palindrom([7, 4, 8, 42,13]) = [13, 42, 8, 4, 7]
 

Rauschkugel

Mitglied
Okay, ihr habt mir schon ein bisschen weitergeholfen :) Nur ganz funktioniert es noch nicht :(
Also ich hab jetzt nur noch eine for-Schleife gemacht und versucht den Index da neu zu bestimmen:

for (int i=0; i<a.length; i++){
a=a[a.length-i-1];

--> leider kommt dann das raus: [13,42,8,42,13]
Ich denk mal, weil nach jedem Schleifendurchgang das Array schon so abgespeichert wird und wenn man dann bei den letzten Durchgängen den Wert am Anfang des Arrays haben möchte, dann kommt nicht der alte Wert, sondern einer der schon bereits ausgewechselt wurde, deswegen die Spiegelung oder?
Wie kann ich das verhindern?
 

minzee

Bekanntes Mitglied
Wie würdet ihr 9.1 a) programmieren?
Java:
class Main
{
   private static long sum(int[] a) throws Exception
   {
      long s = 0; 
      for(int i = 0; i < a.length; ++i)
      {
         if(a[i] > Long.MAX_VALUE - a[i])
         {
            throw new Exception("overflow");
         }
         s += a[i];
      }
      return s;
   }
   public static void main(String[] args)
   {
      try
      {
         int[] a = {7, 4, 8, 42, 13};
         long s = sum(a);
         System.out.println(s);
      }
      catch(Exception e)
      {
         System.out.println("error");
      }
   }
}
So?
 
Zuletzt bearbeitet:

minzee

Bekanntes Mitglied
Und b)?
Java:
class Main
{
   private static int min(int[] a) throws Exception
   {
      if(a.length == 0)
      {
         throw new Exception("length");
      }
      int min = a[0];
      for(int i = 1; i < a.length; ++i)
      {
         if(a[i] < min)
         {
            min = a[i];
         }
      }
      return min;
   }
   public static void main(String[] args)
   {
      try
      {
         int[] a = {7, 4, 8, 42, 13};
         int m = min(a);
         System.out.println(m);
      }
      catch(Exception e)
      {
         System.out.println("error");
      }
   }
}
 

fLooojava

Bekanntes Mitglied
abgesehen mal von den Aufgaben - weshalb arbeitest du bereits mit Exceptions?

Sollte aber passen, habs auch so ;).
 
Zuletzt bearbeitet:

njans

Top Contributor
Java:
if(a[i] > Long.MAX_VALUE - a[i])
Also die Abfrage würde ich mir an deiner Stelle nochmal überlegen ;)
Long ist 64 bit, int nur 32. Wenn die Bedingung jemals wahr wird dann prost Mahlzeit.
 

Flown

Administrator
Mitarbeiter
Also Überlauf kann man mit Java 8 einfach überprüfen:

Java:
Math.addExact(int x, int y);
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
A Palindrom Java Basics - Anfänger-Themen 3
sserio Größtes Palindrom-Produkt Programm funktioniert nur halb Java Basics - Anfänger-Themen 23
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
P Programm Hilfe Palindrom Java Basics - Anfänger-Themen 6
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
D Palindrom Java Basics - Anfänger-Themen 15
H Palindrom Programm Java Basics - Anfänger-Themen 8
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
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
P Objekt einer Methode eines anderen Objektes übergeben 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
laxla123 Eigenschaften eines Algorithmus (determiniert vs.. deterministisch) Java Basics - Anfänger-Themen 2
monsterherz Ablauf der Erstellung eines Java Programmes Java Basics - Anfänger-Themen 17
monsterherz Fehler Semikolon fehlt - ich weiss aber nicht wo da noch eines hin sollte... Java Basics - Anfänger-Themen 21
J Farbe des Striches eines TitledBorders ändern Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
walid Öffnungszeiten eines Geschäftes Java Basics - Anfänger-Themen 3
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
T Probleme beim Import eines Git-Repos Java Basics - Anfänger-Themen 2
U Eigenschaft eines JTextfiels per ActionListener ändern... Java Basics - Anfänger-Themen 2
B Synchronisation eines kleinen Museums Java Basics - Anfänger-Themen 47
krgewb Breite und Höhe eines Bildes in base64 auslesen Java Basics - Anfänger-Themen 3
Sachinbhatt Was ist die Notwendigkeit eines Sammlungsframeworks in Java? Java Basics - Anfänger-Themen 2
N Textdatei aus Resourcen-Ordner eines Projekts/ jar-file lesen Java Basics - Anfänger-Themen 4
B Produkt eines double - streams Java Basics - Anfänger-Themen 3
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
S Variablen Letzte Zeile eines Strings entfernen Java Basics - Anfänger-Themen 1
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
sserio Java Fx, wie erstellt man einen EventHandler, der durch das Drücken eines Button Texte in eine Table view einfügt Java Basics - Anfänger-Themen 17
J Größe eines Strings in Pixel Java Basics - Anfänger-Themen 18
M Parse-Tree eines statements darstellen Java Basics - Anfänger-Themen 0
H Java verkettete Liste, Wert eines Index zurückgeben Java Basics - Anfänger-Themen 1
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Hinzufügen eines Objektes in ein Objekt-Array Java Basics - Anfänger-Themen 62
M Wie kann die Implementation einer Methode den Wert eines Attributs vermindern? Java Basics - Anfänger-Themen 3
A Rekursive Implementation eines Codes Java Basics - Anfänger-Themen 4
H String Repräsentation eines Rechtecks mit Instanz-Methode Java Basics - Anfänger-Themen 8
M Konstruktor ohne Übergabe eines Wertes Java Basics - Anfänger-Themen 7
M Wie kann ich in einem Konstruktor die Methode eines anderen Interfaces mit den jeweiligen Parametern aufrufen? Java Basics - Anfänger-Themen 8
M Wie erreiche ich das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 2
M Wie erreiche ich es das Vorwärtsgehen eines Roboters? Java Basics - Anfänger-Themen 0
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
A Optimierung eines Programms: Mergen der Dateien Java Basics - Anfänger-Themen 23
melisax Alle Möglichkeiten eines Wortes angeben Java Basics - Anfänger-Themen 3
A Java, verarbeitung eines xml-files Java Basics - Anfänger-Themen 2
C Fehler beim erstellen eines Objektes Java Basics - Anfänger-Themen 3
B Konkatenieren eines Strings und inkremtierenden Zahl zu einer INT Variablen Java Basics - Anfänger-Themen 7
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
C Brauche Hilfe beim Schreiben eines Programmes :/ Java Basics - Anfänger-Themen 1
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
C Überprüfen eines Programms auf Syntaxfehler Java Basics - Anfänger-Themen 3
S Wie kann ich den Bereich eines Integers begrenzen? Java Basics - Anfänger-Themen 2
nonickatall Grundsätzliches Verständnisproblem des Aufbaus eines Programms Java Basics - Anfänger-Themen 19
B Downgrade eines bestehenden Projektes Java Basics - Anfänger-Themen 5
amelie123456 Geschwindigkeit der Methode bewegeDich eines Objekts ändern Java Basics - Anfänger-Themen 2
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J maximaler Wert eines Integers Java Basics - Anfänger-Themen 14
TimoN11 IntelliJ , Ausgabe von einem Quellcode in Eingabe eines Quellcodes Java Basics - Anfänger-Themen 1
Z Rückgabe eines Values in umgekehrte richtung Java Basics - Anfänger-Themen 5
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
B fragen zu Aufbau eines UML-Klassendiagramm Java Basics - Anfänger-Themen 1
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
M Benutzereingabe eines Codes verbessern Java Basics - Anfänger-Themen 3
B Modulo-Operator anhand eines Beispieles erklären Java Basics - Anfänger-Themen 7
J Verschieben von Buchstaben in einem String um vorgegebene Anzahl von Zeichen innerhalb eines weiteren String Java Basics - Anfänger-Themen 12
F Auf Variablen eines Konstruktors zugreifen Java Basics - Anfänger-Themen 4
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
marcooooo Separator zwischen allen Zeichen eines Strings einfügen Java Basics - Anfänger-Themen 29
C Wie kann ich Versionen eines Projektes in Eclipse erstellen? Java Basics - Anfänger-Themen 3
yoskaem Text Color durch Klicken eines Buttons in anderer Activity ändern Java Basics - Anfänger-Themen 2
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
P Klasse hat keinen Zugriff auf getter/setter-Methoden eines Objektes Java Basics - Anfänger-Themen 9
R Löschen und ausgeben eines Teilbaums Java Basics - Anfänger-Themen 3
J Alle Werte eines Strings zusammen addieren Java Basics - Anfänger-Themen 15
M Hilfe bei Strukturierung eines Buchungssystems Java Basics - Anfänger-Themen 3
M Erstellen eines insets Objekts, GridBagLayout Java Basics - Anfänger-Themen 13
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14

Ähnliche Java Themen

Neue Themen


Oben