Backtracking/Solve Methode

M

Michael789

Gast
HI


Es geht darum dass ich ein 5x5 Array hab mit diesem Rätsel "Es gibt 5 häuser in 5 verschiedenne farben, in jedem wohnt einer mit unterschiedlicher Nationalität, hat ein unetrschiedliches Haustier uswusw.
Das soll mit Bcktracking rekursiv gelöst werden, sollte auch soweit passen.
ABER: Ich verwende oft die Methode isEmpty().
Muss die nicht implementiert werden? Oder kann ich allgemein abfragen ob ein Array null ist mit arr[y][x].isEmpty(); geht das?

Jedenfalls sagt er mir beim Ausführen in Z115: null pointer Exception?! Woran liegt das?

Danke schon mal.

Java:
public class Einstein
{
  /**Spalten Inex der Eigenschaften*/
  private static final int NATION = 0;
  private static final int HOUSE_COLOR = 1;
  private static final int PET = 2;
  private static final int DRINK = 3;
  private static final int CIGARETTE = 4;
  
  /**Mögliche Werte der Spalten*/
  private static String[] nations = {"dane", "swede", "german", "norway", "briton"};
  private static String[] houseColors = {"red", "yellow", "green", "white", "blue"};
  private static String[] pets = {"cat", "dog", "fish", "bird", "horse"};
  private static String[] drinks = {"coffee", "milk", "beer", "water", "tee"};
  private static String[] cigarettes = {"pall mall", "dunhill", "marlboro", "winfield", "rothmanns"};
  
  /**Array aller möglichen Attribute*/
  private static String[][] properties = {nations, houseColors, pets, drinks, cigarettes};
  
  /**Lösungstabelle*/
  private static String[][] table = new String[5][5];
  
  /**Main Methode*/
  public static void main (String[] arg)
  {
      solve(); /**Rekursiv lösen*/
      if((pruefeGueltigkeit()==true)&&(pruefeVollstaendigkeit()==true))
      {
          System.out.println("Einstein geloest");
        }
      else
      {
          System.out.println("Keine Loesung moeglich!");
        }
  }
  private static void solve(){
     // Falls keine gueltige Loesung entstanden ist, Aufruf abbrechen
     if(!pruefeGueltigkeit())
      return;
     //nächstes freies Feld holen
     int[] index = getNextEmpty();
     //pruefen ob Tabelle vollstaendig ausgefuellt. Falls ja, Rekursion abbrechen
     if(pruefeVollstaendigkeit())
      return;
     //prüfen aus welcher Spalte das leere feld kommt um zu wissen welche Werte (woerter) ausprobeirt werden muessen
     if(index[1]==0){
         for(int i=0;i<table[0].length;i++){
             table[index[0]][index[1]]=nations[i];
             solve();
             if(pruefeGueltigkeit()&&pruefeVollstaendigkeit())
               return;
         }
         table[index[0]][index[1]]=null;
        }
     if(index[1]==1){
         for(int i=0;i<table[0].length;i++){
             table[index[0]][index[1]]=houseColors[i];
             solve();
             if(pruefeGueltigkeit()&&pruefeVollstaendigkeit())
               return;
         }
         table[index[0]][index[1]]=null;
     }
     if(index[1]==2){
         for(int i=0;i<table[0].length;i++){
             table[index[0]][index[1]]=pets[i];
             solve();
             if(pruefeGueltigkeit()&&pruefeVollstaendigkeit())
               return;
         }
         table[index[0]][index[1]]=null;
     }
     if(index[1]==3){
         for(int i=0;i<table[0].length;i++){
             table[index[0]][index[1]]=drinks[i];
             solve();
             if(pruefeGueltigkeit()&&pruefeVollstaendigkeit())
               return;
         }
         table[index[0]][index[1]]=null;
     }
     if(index[1]==4){
         for(int i=0;i<table[0].length;i++){
             table[index[0]][index[1]]=cigarettes[i];
             solve();
             if(pruefeGueltigkeit()&&pruefeVollstaendigkeit())
               return;
         }
         table[index[0]][index[1]]=null;
     }
  }
  private static boolean pruefeVollstaendigkeit()
  {
       for(int i=0;i<table.length;i++)
      {
          for(int j=0;j<table[0].length;j++)
          {
              if(table[j][i]==null)
               return false;
          }
      }
      return true;
  }
  
  public static boolean pruefeGueltigkeit()
  {
      /**Ueberprueft ob ein Eintrag doppelt vorkommt.
         In keine Spalte darf ein Eintrag doppelt vorkommen. Regeln 1-4*/
      for(int propertyIdx=0; propertyIdx < table[0].length; propertyIdx++)
      {
          for(int houseIdx1=0; houseIdx1 < table.length-1; houseIdx1++)
          {
              for(int houseIdx2=houseIdx1+1; houseIdx2 < table.length; houseIdx2++)
              {
                  if(table[houseIdx1][propertyIdx].isEmpty())
                  {
                      continue;
                  }
                  /**Wenn ein Eintrag doppelt vorkommt*/ 
                  if(table[houseIdx1][propertyIdx].equals(table[houseIdx2][propertyIdx]))
                  {
                      return false;
                  }
  
                }
            }
        }
    
  
     /**Ueberpruefen der Regeln fuer jede Zeile, eine Zeile entspricht einem Haus
     * Wenn eine Regel verletzt wird wird false zurückgegeben*/
     for(int houseIdx=0; houseIdx < table.length; houseIdx++)
     {
         /**Regel 5; Der Norweger wohnt im ersten Haus, houseIdx ==0 => erstes Haus*/
         if(houseIdx==0)
         {
             if(!table[houseIdx][NATION].isEmpty()&&!table[houseIdx][NATION].equals("norway"))
             {
                 return false;
             }
             
         }
         if(!table[houseIdx][NATION].isEmpty()&&table[houseIdx][NATION].equals("briton")&&table[houseIdx][PET].equals("cat"))
            return false;
         if(!table[houseIdx][NATION].isEmpty()&&table[houseIdx][NATION].equals("german")&&table[houseIdx][CIGARETTE].equals("rothmanns")&&!table[houseIdx][DRINK].equals("coffee"))
            return false;
         if(houseIdx==0&&table[houseIdx][HOUSE_COLOR].equals("white"))
            return false;
         else if(houseIdx==4&&table[houseIdx][HOUSE_COLOR].equals("green"))
            return false;
         else if(houseIdx!=4&&table[houseIdx][HOUSE_COLOR].equals("green")&&!table[houseIdx][HOUSE_COLOR+1].isEmpty()&&!table[houseIdx][HOUSE_COLOR+1].equals("white"))
            return false;
         if(!table[houseIdx][CIGARETTE].equals("pall mall")&&!table[houseIdx][PET].isEmpty()&&!table[houseIdx][PET].equals("bird"))
            return false;
     }
     
     /**keine Regel verletzt*/
     return true;
  }
  /**Diese Methode liefert ein zweidimensionales Array mit den Koordinaten des naechsten freien Feldes*/
  public static int[] getNextEmpty()
  {
      int[] a1 = new int[2];
      a1[0]=-1;
      a1[1]=-1;
      for(int i=0;i<table[0].length;i++)
         {
            for(int j=0;j<table.length;j++)
            {
                if(table[i][j]==null)
                { 
                    a1[0]=i;
                    a1[1]=j;
                    return a1;
                }
            }
         }
      
      return a1;
    }

}
 
M

Michael789

Gast
Und falls ich die isEmpty() MEthode brauch, bitte ein kleiner Denkanstoß wie ich die Objektorientiert implementiere.Ich steh gerade auf dem Schlauch. Mit isEmpty(arr[y][x]) köma ich klar. Aber wenn ich keine Parameter übergeben will, wie löse ich das dann?
 

Marco13

Top Contributor
Wenn in Zeile
Code:
if(table[houseIdx1][propertyIdx].isEmpty())
eine NPE kommt, liegt das daran, dass
Code:
table[houseIdx1][propertyIdx]
dort ' null' ist.

Vielleicht reicht schon ein
Code:
if(table[houseIdx1][propertyIdx] == null)

Aber nachvollziehen werde ich den Code sicher nicht....
 
Zuletzt bearbeitet von einem Moderator:
M

Michael789

Gast
Danke, die ist schon mal beseitigt.
Die nächste hab ich in Z147.
Hier ist das Feld wohl auch leer.
Die If Abfrage (2ter Teil) soll aber true sein, wenn im Feld "white" drin steht. Steht etwas anderes ODER null drin soll die If Abfrage false sein. (Also das IM if...nicht das was er dann zurück gibt).
Wie realisiere ich das dann?
Problem ist wohl dass es in das Feld schaut und nichts drin steht, oder?
 
S

SlaterB

Gast
grundsätzlich kann man bei String solche Vergleiche umdrehen
Java:
"test".equals(variable)
funktioniert auch wenn variable null ist, liefert dann false
 
M

Michael789

Gast
grundsätzlich kann man bei String solche Vergleiche umdrehen
Java:
"test".equals(variable)
funktioniert auch wenn variable null ist, liefert dann false

danke. hab dann aber folgendes problem:

Java:
"white".equals(!table[houseIdx][HOUSE_COLOR+1])
ist nicht zulässig da ! bei String nicht zulässig ist. wie verneine ich das dann?
Also "Wenn der Inhalt nicht "white" ist will ich ein true haben
 
M

Michael789

Gast
yeah, jetzt funktioniert alles!
Danke leute für den großartigen und vor allem schnellen Support!
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Max246Sch 3D Box Filler BAcktracking Java Basics - Anfänger-Themen 1
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
districon Backtracking Java Basics - Anfänger-Themen 2
districon Backtracking Java Basics - Anfänger-Themen 14
districon Dynamisch Programmierung/Backtracking/Memoization Java Basics - Anfänger-Themen 3
districon Backtracking funktioniert nicht ganz Java Basics - Anfänger-Themen 3
V Backtracking und Rekursion Java Basics - Anfänger-Themen 15
G Subset sum problem mit Backtracking Java Basics - Anfänger-Themen 18
O Backtracking Java Basics - Anfänger-Themen 5
C Rekursives Backtracking beim Spiel Peg Java Basics - Anfänger-Themen 22
A Backtracking Java Basics - Anfänger-Themen 56
R Backtracking Java Basics - Anfänger-Themen 1
V Feld sortieren mit Backtracking Java Basics - Anfänger-Themen 1
A Sudoku mit Backtracking lösen Java Basics - Anfänger-Themen 3
L Sudoku Backtracking Pseudocode Java Basics - Anfänger-Themen 3
N Backtracking - Labyrinth/Irrgarten Java Basics - Anfänger-Themen 14
I Backtracking Schach Java Basics - Anfänger-Themen 5
L Magisches Quadrat und Backtracking Java Basics - Anfänger-Themen 19
P Labyrinth, Backtracking, verzögerte Anzeige Java Basics - Anfänger-Themen 15
D Sudoku lösen mit Backtracking Java Basics - Anfänger-Themen 20
E backtracking und Induktionsprinzip Java Basics - Anfänger-Themen 2
D Backtracking Waage Problem Java Basics - Anfänger-Themen 23
N Backtracking Solohalma Java Basics - Anfänger-Themen 2
W Backtracking und Frustration Java Basics - Anfänger-Themen 6
X Sudoku Backtracking Java Basics - Anfänger-Themen 6
J Solitaire via Backtracking Java Basics - Anfänger-Themen 7
A Backtracking - kennt Java keine Rücksprungmarken? Java Basics - Anfänger-Themen 15
G Backtracking mit globaler Variable Java Basics - Anfänger-Themen 5
M BackTracking Java Basics - Anfänger-Themen 22
J Backtracking Algorithmus Java Basics - Anfänger-Themen 16
T Verschiedene Optionen in der Methode Java Basics - Anfänger-Themen 6
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
til237 Iterative Methode in rekursive Methode umschreiben Java Basics - Anfänger-Themen 4
M Daten aus errechneter Methode in Datenbank(SQLite) schreiben Java Basics - Anfänger-Themen 60
D next() Methode mehrfach verwenden Java Basics - Anfänger-Themen 1
Ostkreuz Methoden Von Dezimal zu Hexadezimal Methode toHex Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
N Throw an Main Methode übergeben Java Basics - Anfänger-Themen 7
M Methoden Methode 'wiederhole' nicht gefunden (Uebersetzungsfehler) Java Basics - Anfänger-Themen 1
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
M Anzahl Kommandozeilenparamter mittels Methode Java Basics - Anfänger-Themen 11
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
J Die statische Main-Methode ändert Instanzvariable? Java Basics - Anfänger-Themen 10
D Methode aus dem Aufrufer aufrufen Java Basics - Anfänger-Themen 1
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
U Beispiel Methode size() vom "Collection"-interface... Wie kann man sichtbar machen, was die Methode unter der Haube macht? Java Basics - Anfänger-Themen 8
D Warum kann ich hier nicht auf die Methode zugreifen? Java Basics - Anfänger-Themen 5
M generate Methode für Streams Java Basics - Anfänger-Themen 6
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
I Optionaler Parameter bei Methode, der nur optional ist? Java Basics - Anfänger-Themen 6
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
T Linked List set-Methode Java Basics - Anfänger-Themen 2
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
W Equals-Methode überschreiben bei composition Java Basics - Anfänger-Themen 20
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
V Methoden printChar Methode mit Rückgabetyp void Java Basics - Anfänger-Themen 26
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
berserkerdq2 wie funktioniert contenthandler, was muss ich bei der Methode startElement und endElement tun? Java Basics - Anfänger-Themen 11
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
S Methode Java Basics - Anfänger-Themen 4
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4

Ähnliche Java Themen

Neue Themen


Oben