BitSet- Objekt- Anzahl der Elemente bestimmen

Pödödö

Neues Mitglied
Hi Leute;

für meine Facharbeit habe ich ein Programm programmiert, dass Sudokus mit Hilfe von Backtracking löst. Das ganze hab ich jetzt dank guter Literatur endlich fertig, obwohl meine Kenntnisse eher sehr gering sind.
Um festzustellen, ob es möglich ist, eine Zahl an eine bestimmt Stelle einzusetzen, habe ich zuerst alle Zahlen einer Zeile/einer Spalte/ eines Blocks in BitSets gemerkt. Mit der Methode get() konnte ich dann kucken, ob die Zahl schon in der Zeile/Spalte/Block vorkommt. Hat alles super funktioniert.

Nun möchte ich das Programm noch verbessern, wie es in dem Buch von meinem Lehrer vorgeschlagen wird: "Ersetzen Sie die "do-while" - Schleife in füllen() durch eine Schleife, die für jedes freie Feld die Vereinigung der Mengen aus zeile[],spalte[],block[] bestimmt und die Position ausgibt, an der die Vereinigungsmenge die größte Anzahl von Elementen hat."

Vom Sinn her hab ich das verstanden, wenn in der Vereingungsmenge schon 8 Elemente sind, ist das Feld eindeutig, es gibt weniger Fehlversuche... Nur komm ich mit BitSet als Klasse offensichtlich nicht klar! Um die Vereinungsmenge zu bilden, habe ich or() genutzt und um die Anzahl der summe zu bekommen, size(). Schade, dass da dann immer nur 64 rauskommt , und nicht eine Zahl zwischen 0-9 :/.

Ich hab wirklich schon lange gewerkelt und gegoogelt, also wäre es nett, wenn ihr euch das mal anschaut. Euer Forum gefällt mir nämlich super :toll: Es darf auch wirklich gerne an meinem schlechten Stil und meinen groben Schnitzern genörgelt werden ;)

Java:
import java.io.*;
import java.util.*;

public class sudoku{
  private static int[][] feld;
  private static final int N = 3; // Konstante 
  private static final int DIM = N*N; // Konstante für die größe des Sudokus
  private static BitSet zeile[];
  private static BitSet spalte[];
  private static BitSet[][] block;
  private static int unmöglich=0;
  private static int[][] möglichkeiten; 
  //Atribute der Klasse
  sudoku(int[][] werte){               //Konstruktor
    feld = werte;
    this.zeile = new BitSet[DIM];
    this.spalte = new BitSet[DIM];
    for(int z = 0; z < DIM; z++){
      this.zeile[z]= new BitSet();
      this.spalte[z] = new BitSet();
    }
    this.block= new BitSet[N][N];
    for(int z= 0 ;z<N;z++) {
      for (int s=0;s<N; s++) {
        block[z][s] = new BitSet();
      } // end of for
    } // end of for
    for (int z= 0;z<DIM ;z++) {
      for (int s=0;s<DIM ;s++) {
        if (feld[z][s]!=0) {
          zeile[z].set(feld[z][s]);
          spalte[s].set(feld[z][s]);
          block[z/N][s/N].set(feld[z][s]);
        } // end of if
      } // end of for
    } // end of for  
  }                                          //Konstruktor Ende
  public static void main(String args[]){
    int[][] werte = {
      {0,0,0,9,0,0,7,2,8}, //z=0
      {2,7,8,0,0,3,0,1,0}, //z=1
      {0,9,0,0,0,0,6,4,0}, //..
      {0,5,0,0,6,0,2,0,0},
      {0,0,6,0,0,0,3,0,0},
      {0,1,0,0,5,0,0,0,0},
      {1,0,0,7,0,6,0,3,4},
      {0,0,0,5,0,4,0,0,0},
      {7,0,9,1,0,0,8,0,5}
    };//s=0,s=1;..
    new sudoku(werte);
    ausgabe();
    füllen();       //  füllen(0, -1) für die erste Version
    ausgabe();
  }                                 
  
  
  public static void füllen(){         //int s, int z für die Erste Version
    /*do { 
    s++;
    if (s==DIM) {                                          //Erste Version ;)
    s=0;
    z++;
    if (z==DIM) {                                      //Abbruchbedingung
    ausgabe();
    return;                                          //Das Ende: alle Felder voll
    } // end of if
    } // end of if
    } while (feld[z][s] !=0);                  //nächstes leeres Feld finden
    */
    BitSet summe= new BitSet();
    int z=0;
    int s=0;
    int Anzahl=0;
    for (int a=0;a<DIM;a++) {
      for (int t=0;t<DIM;t++) {
        if (feld[a][t]==0) {
          summe= zeile[a];
          summe.or(spalte[t]);
          summe.or(block[a/N][t/N]);
          Anzahl=summe.size();
        } // end of if
      } // end of for
    } // end of for
    if (Anzahl==9) {
      ausgabe();
      return;
    } // end of if
    for (int wert=1;wert<=DIM; wert++) {
      if (möglich(z,s,wert)) {                 //möglichen Wert finden
        einsetzen(z,s,wert);
        füllen();                           //Rekursion:die nächsten Felder füllen
        löschen(z,s);                          //falschen Wert löschen
      } // end of if
    } // end of for
    unmöglich++;
  } 
  public static void einsetzen(int z, int s, int wert){
    feld[z][s]=wert;
    zeile[z].set(wert);
    spalte[s].set(wert);
    block[z/N][s/N].set(wert);
  }
  
  public static void löschen(int z, int s){ 
    zeile[z].clear(feld[z][s]);
    spalte[s].clear(feld[z][s]);
    block[z/N][s/N].clear(feld[z][s]);
    feld[z][s]=0;
  } 
  static boolean möglich(int z, int s, int wert){                      //Sudokubedingung 
    if (!zeile[z].get(wert)
    && !spalte[s].get(wert)
    && !block[z/N][s/N].get(wert))
    {
      return true;
    } // end of if
    else{
      return false;
    }
  }
  
  public static void ausgabe(){
    for (int z=0;z<DIM;z++) {
      for (int s=0;s<DIM ;s++ ) {
        System.out.print(feld[z][s]+" "); 
      } // end of for
      System.out.print("\n");
    } // end of for
    System.out.print(unmöglich);
    System.out.print("Fehlversuche\n");
  }
}
 
N

nillehammer

Gast
Zunächst zu Deiner Frage. Ich habe Deinen Code nicht bis ins letzte nachvollzogen. Aber Dein Text klingt danach, dass Du nicht size() (Anzahl der möglichen Bits), sondern cardinality() (anzahl der gesetzten Bits) brauchst, um sie zu addieren.

Und nun allgemeines Gemecker;):
- Klassennamen groß also "Sudoku"
- Überlege mal genau, was an deinen Variablen static sein muss (also Klassenvariable, einmal gleich für alle Instanzen) und was nicht (also jeweils pro Instanz gültig). Zumindest für die Felder, die Du im Konstruktor belegst, scheint static falsch.
-Dreifach geschachtelte Konstrukte sind schlecht lesbar. Ich wette, dass selbst Du, wenn Du in 1 Woche Deinen eigenen Code anschaust, weder den Ablauf nachvollziehen kannst, noch weißt, WAS Du da machen wolltest. Hinter den Schleifen/Ifs steckt ein fachliches Konzept. Versuche, für dieses Konzept einen Namen zu finden (bspw. fuelleZeile oder so), definiere die benötigten Parameter und Rückgabewerte und lager es in Methoden aus.
[EDIT]
- Keine Sonderzeichen in Namen also besser moeglich() statt möglich()
- Methodennamen immer mit Verb (Tu-Wort) beginnen lassen also besser istZahlMoeglich(int zahl) statt moeglich(int zahl)
[/EDIT]
 
Zuletzt bearbeitet von einem Moderator:

Pödödö

Neues Mitglied
okay, vielen Dank,

ich werde das mit cardinality() mal probieren, und auch die anderen Sachen beachten! Schreibe dann nochmal, ob es funktioniert hat ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
W Fehler bei einem BitSet in einem Objekt Java Basics - Anfänger-Themen 2
F BitSet und ByteArray Java Basics - Anfänger-Themen 0
D BitSet verständinsprobleme Java Basics - Anfänger-Themen 1
F BitSet problem Java Basics - Anfänger-Themen 7
G BitSet() in Methoden übergeben. Java Basics - Anfänger-Themen 2
H toString(); varargs; bitSet Java Basics - Anfänger-Themen 8
G Klasse BitSet Java Basics - Anfänger-Themen 2
krgewb Über Objekt, das Objekte desselben Typs enthält iterieren Java Basics - Anfänger-Themen 5
M Ausgabe einer ArrayList ensteht nur als Hashcode, nicht als Objekt Java Basics - Anfänger-Themen 16
Rxiiz Objekt aus ComboBox entfernen Java Basics - Anfänger-Themen 4
I JSON in Objekt umwandeln Java Basics - Anfänger-Themen 3
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
I Klassen von einem package laden, Statisches Feld auslesen und Objekt erstellen Java Basics - Anfänger-Themen 8
B Objekt aus generalisierter Liste entfernen Java Basics - Anfänger-Themen 11
Soranix Erste Schritte Struktur als Anfänger // Von einer Klasse auf ein Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 6
Say Objekt Java Basics - Anfänger-Themen 4
Say abstract class und Objekt erzeugen - Dringend Hilfe Java Basics - Anfänger-Themen 10
T Wie kann man es machen das ein Objekt nicht übermalt wird Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
K warum kann ich das Objekt nicht erstellen ? Java Basics - Anfänger-Themen 2
K wie kann ich alle Attribute von dem Objekt(pagode) ausgeben lassen ? Java Basics - Anfänger-Themen 3
H Ein übergegebenes Objekt auf null setzen Java Basics - Anfänger-Themen 9
M BlueJ Objekt in Objektliste Java Basics - Anfänger-Themen 2
B Objekt in Klassendiagramm an fremdes Objekt weiterreichen? Java Basics - Anfänger-Themen 6
Fodoboo131 RegEx- Umwandlung von String in ausführbares Objekt/ Befehl Java Basics - Anfänger-Themen 9
frager2345 Aufgabe Hash Objekt Elemente ausgeben Java Basics - Anfänger-Themen 2
amelie123456 Objekt Farbe Quellcode Java Basics - Anfänger-Themen 4
M Objekt in einem Objekt speichern Java Basics - Anfänger-Themen 9
U Warum kann ich, auf private Variablen zugreifen, wenn ich ein Objekt in der Klasse, die private Variablen hat erstelle und dort drauf zugreifen will? Java Basics - Anfänger-Themen 7
missy72 Klassen Objekt Array NullPointerException Java Basics - Anfänger-Themen 3
J Hinzufügen eines Objektes in ein Objekt-Array Java Basics - Anfänger-Themen 62
O Warum bekommen wir nicht die Referenz vom zurückgegebenen Objekt? Java Basics - Anfänger-Themen 4
K Ein Objekt Auto kennt den Inhalt seines links und rechtsstehenden Autos, wie soll man das ermöglichen Java Basics - Anfänger-Themen 2
W Unterschiede bei Zugriff auf Objekt und Klassenvariablen über einen Getter? Java Basics - Anfänger-Themen 2
melaniemueller Fernseher als Objekt Java Basics - Anfänger-Themen 9
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
Nina Pohl Ein Vorgang bezog sich auf ein Objekt, das kein Socket ist Java Basics - Anfänger-Themen 6
B Objekt kopieren und sämtliche Referenzen von diesem Objekt? Java Basics - Anfänger-Themen 3
S JavaFX - Objekt an neue Stage übergeben Java Basics - Anfänger-Themen 12
T Verständnisfrage Objekt Getter Setter Java Basics - Anfänger-Themen 102
P Objekt in mehreren Methoden verwenden. Java Basics - Anfänger-Themen 3
S Aufzurufendes Objekt Java Basics - Anfänger-Themen 3
CptK Überprüfen ob übergebenes Objekt zu Generics passt Java Basics - Anfänger-Themen 2
C Konstruktor ab serialisiertem Objekt Java Basics - Anfänger-Themen 4
Kalibru Problem bei Ausgabe von Objekt Java Basics - Anfänger-Themen 1
P Wie rufe ich Methoden mit einer Referenz auf eine Klasse||Objekt auf Java Basics - Anfänger-Themen 4
J Input/Output Konstruktor ergänzen, der zur Datei mit einem Objekt passt Java Basics - Anfänger-Themen 0
P Ein Objekt nach einem String durchsuchen? Java Basics - Anfänger-Themen 7
S Objekt aus Arraylist in andere Arraylist kopieren? Java Basics - Anfänger-Themen 2
J Objekt-Array dynamischer Länge aus Benutzereingaben erstellen Java Basics - Anfänger-Themen 6
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
B Interface List - Objekt übergeben? Einzelnes Objekt geht, aber Liste nicht? Java Basics - Anfänger-Themen 4
B Objekt von EJB in Controller (CDI) - Klasse füllen? Java Basics - Anfänger-Themen 3
L Zufälliges Objekt aus der ArraylList ohne java.util.Random Java Basics - Anfänger-Themen 56
N LocalTime einem Objekt zuweisen Java Basics - Anfänger-Themen 2
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
M Wie kann ich ein Objekt erstellen, wenn sich der Klassenname in einer Variablen befindet? Java Basics - Anfänger-Themen 10
R Zugriff auf den Index eines Arrays, welches ein Objekt ist. Java Basics - Anfänger-Themen 4
tom.j85 Doppelte Foreach Schleife: Am Ende wird immer das Gleiche Objekt eingefügt Java Basics - Anfänger-Themen 4
J RSA Verschlüsselung Testen / byte[] in Objekt umwandeln Java Basics - Anfänger-Themen 1
M ArrayList - Objekt kopieren und ändern Java Basics - Anfänger-Themen 11
L Objekt an Methode übergeben Java Basics - Anfänger-Themen 4
S Spiel-Programmieren. Wenn ein Objekt den anderen berührt. Java Basics - Anfänger-Themen 6
J Y-Koordinate von GUI-Objekt bestimmen Java Basics - Anfänger-Themen 2
M Auf erstelltes Objekt einer anderen Klasse zugreifen. Java Basics - Anfänger-Themen 5
H Referenz Objekt aufrufen Java Basics - Anfänger-Themen 12
M Objekt mit eindeutiger ID löschen, das nächste Objekt hat dann diese ID Java Basics - Anfänger-Themen 5
N Mit Objekt der Superklasse auf Methode der Subklasse zugreifen Java Basics - Anfänger-Themen 6
E Objekt durch Benutzer über Konsole erzeugen - Java Java Basics - Anfänger-Themen 3
J Objekt bei Auswahl in jList ändern Java Basics - Anfänger-Themen 6
Kirby.exe Generische Objekt Instanz erstellen Java Basics - Anfänger-Themen 14
H Objekt aus einem Array löschen Java Basics - Anfänger-Themen 1
H Objekt im Array speichern Java Basics - Anfänger-Themen 2
H Objekt mit Methode erstellen Java Basics - Anfänger-Themen 6
H Objekt als Attribut speichern Java Basics - Anfänger-Themen 11
E Was kommt in ein Objekt und was in die Main Methode? Java Basics - Anfänger-Themen 8
R Objekt in Konstruktor ist nicht zulässig Java Basics - Anfänger-Themen 5
W OOP Objekt Methode Java Basics - Anfänger-Themen 9
A Objekt in Arrayliste Java Basics - Anfänger-Themen 2
B Mit methode Objekt aus anderer Klasse erstellen Java Basics - Anfänger-Themen 6
I Object-Oriented Programming, Objekt erzeugen Java Basics - Anfänger-Themen 1
M Objekt einer Klasse speichert die Veränderung nicht Java Basics - Anfänger-Themen 1
K Konstruktor für ein Objekt mit Zugriffsmethoden Java Basics - Anfänger-Themen 7
S Variablen Klassenvariable über Objekt aufrufen Java Basics - Anfänger-Themen 16
A Zufälliges Objekt basierend auf Wahrscheinlichkeiten bekommen. Java Basics - Anfänger-Themen 4
R Value von einem JSON-Objekt ausgeben Java Basics - Anfänger-Themen 4
P Objekt aus String-Array erzeugen Java Basics - Anfänger-Themen 104
N Bewegtes Objekt soll sich um eine Parallele bewegen Java Basics - Anfänger-Themen 0
S Objekt-Attribute "variabel" gestalten Java Basics - Anfänger-Themen 10
J Datenbankstruktur als Objekt anlegen Java Basics - Anfänger-Themen 4
L Objekt aus Textdatei in ArrayList speichern Java Basics - Anfänger-Themen 4
B Objekt an neue Stage übergeben? Java Basics - Anfänger-Themen 9
scratchy1 Wie deklariert man eine Methode, die ein Objekt zurückgeben soll? Java Basics - Anfänger-Themen 22
B Klassen Zugriff auf ein Objekt einer Klasse aus einer Methode heraus Java Basics - Anfänger-Themen 4
J Objekt erste freie Stelle zuweisen Java Basics - Anfänger-Themen 3
S Zugriff auf Objekt Java Basics - Anfänger-Themen 5
C Objekt soll ein Array sein. Java Basics - Anfänger-Themen 15
H Vererbung Static Scanner Objekt verwenden - von StdIn in einer importierten Klasse lesen Java Basics - Anfänger-Themen 10

Ähnliche Java Themen

Neue Themen


Oben