Integer-Array variabler Größe mit Zahlen befüllen (Schleifen)

Dibelius

Mitglied
Hallo Gemeinde,

ich grüble nun schon eine Weile an dem Problem, aber der Reihe nach.

Zielstellung: Ich möchte Integer-Arrays erzeugen, die Kombinationen widerspiegeln sollen (und diese später als Schlüssel in einem Map-Objekt ablegen; bereits implementiert).

Es gibt dabei drei Faktoren, die variieren können:
  • Array-Länge, es gibt aber ein bekanntes Maximum (depth)
  • maximale Summe aller Werte im Array (sumCap)
  • Höchstgrenze für jeden einzelnen Integer-Wert (valueCap)
Beispielausgabe: depth = 3, sumCap = 4, valueCap = 2
Java:
// Für eine Zahl
[0, 0, 0]
[0, 0, 1]
[0, 0, 2] // valueCap bei [2] erreicht
[0, 1, 0]
[0, 2, 0] // valueCap bei [1] erreicht
[1, 0, 0]
[2, 0, 0] // valueCap bei [0] erreicht
// Für zwei Zahlen
[0, 1, 1]
[0, 2, 1] // valueCap bei [1] erreicht
[1, 0, 1]
[2, 0, 1] // valueCap bei [0] erreicht
// ...
// Für drei Zahlen
[1, 1, 2] // valueCap bei [2] erreicht, sumCap erreicht
// ...
[2, 0, 2] // valueCap bei [0] und [2] erreicht, sumCap erreicht
// Nicht möglich sind z.B.
[1, 0, 3] // valueCap bei [2] überschritten, sumCap erreicht
[0, 0, 4] // valueCap bei [2] überschritten, sumCap erreicht
[2, 3, 0] // valueCap bei [0] erreicht, bei [1] überschritten, sumCap überschritten
// ...

Beispielausgabe: depth = 5, sumCap = 3, valueCap = 1 (Binärkombinationen)
Java:
// Für eine Zahl
[0, 0, 0, 0, 0]
[0, 0, 0, 0, 1] // valueCap bei [4] erreicht
[0, 0, 0, 1, 0] // valueCap bei [3] erreicht
// ...
// Für zwei Zahlen
[0, 0, 1, 0, 1] // valueCap bei [2] und [4] erreicht
[0, 1, 0, 0, 1] // valueCap bei [1] und [4] erreicht
// ...
// Für drei Zahlen
[0, 0, 1, 1, 1] // valueCap bei [2], [3] und [4] erreicht, sumCap erreicht
[0, 1, 0, 1, 1] // valueCap bei [1], [3] und [4] erreicht, sumCap erreicht
// Nicht möglich sind z.B.
[0, 1, 1, 1, 1] // sumCap überschritten
[0, 1, 0, 0, 2] // valueCap bei [4] überschritten, sumCap erreicht
// ...

Meine derzeitige Holzhammermethode für die Erzeugungsmethode sieht wiefolgt aus (mit besagtem Maximum der Array-Länge von 9):
Java:
   private Hashtable<int[], Integer> createReferenceTable(int depth, int sumCap, int valueCap)
   {
       Hashtable<int[], Integer> table   = new Hashtable<int[], Integer>   (1000, 0.75F);
       //Hashtable<ArrayList<Integer>, Integer> table   = new Hashtable<ArrayList<Integer>, Integer>   (1000, 0.75F);

       int[] pattern = new int[depth];
       //ArrayList<Integer>   pattern   = new ArrayList<Integer>(depth);

       for (int a = 0; a <= valueCap; a++)
       {
           pattern = createTableEntry(depth, sumCap, valueCap, a);
           if (pattern != null) table.put(pattern, new Integer(0));
           for (int b = 0; b <= valueCap; b++)
           {
               pattern = createTableEntry(depth, sumCap, valueCap, a,b);
               if (pattern != null) table.put(pattern, new Integer(0));
               for (int c = 0; c <= valueCap; c++)
               {
                   pattern = createTableEntry(depth, sumCap, valueCap, a,b,c);
                   if (pattern != null) table.put(pattern, new Integer(0));
                   for (int d = 0; d <= valueCap; d++)
                   {
                       pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d);
                       if (pattern != null) table.put(pattern, new Integer(0));
                       for (int e = 0; e <= valueCap; e++)
                       {
                           pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d,e);
                           if (pattern != null) table.put(pattern, new Integer(0));
                           for (int f = 0; f <= valueCap; f++)
                           {
                               pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d,e,f);
                               if (pattern != null) table.put(pattern, new Integer(0));
                               for (int g = 0; g <= valueCap; g++)
                               {
                                   pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d,e,f,g);
                                   if (pattern != null) table.put(pattern, new Integer(0));
                                   for (int h = 0; h <= valueCap; h++)
                                   {
                                       pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d,e,f,g,h);
                                       if (pattern != null) table.put(pattern, new Integer(0));
                                       for (int i = 0; i <= valueCap; i++)
                                       {
                                           pattern = createTableEntry(depth, sumCap, valueCap, a,b,c,d,e,f,g,h,i);
                                           if (pattern != null) table.put(pattern, new Integer(0));
                                       }
                                   }
                               }
                           }
                       }
                   }
               }
           }
       }

       return table;
   }

Validierung des übergebenen values-Arrays und Rückgabe, wenn alle drei Faktoren erfüllt:
Java:
   private int[] createTableEntry(int depth, int sumCap, int valueCap, int...values)
   {
       if (values != null && depth == values.length)
       {
           for (int v : values)
               if (v > valueCap) return null;
         
           sum = ExpArray.sum(values);
           if ( sum <= sumCap)
               return values;
       }
       return null;
   }

Meine kleine Helferfunktion für die Summenbildung
Java:
public class ExpArray
{
    // ...
    /**Sums up items of an integer array, optionally filters values.
     * @param arr        The array to be checked.
     * @param ex        Values to be filtered. If {@code null} all values are valid.
     * @return            Sum of valid items.
     */
    public static int sum(int[] arr, int... ex)
    {
        int sum = 0;
        if (arr != null) {
            for (int n : arr)
            {
                boolean valid = true;
                if (ex != null)
                    for (int e : ex)
                        if (n == e) {
                            valid = false;
                            break;
                        }
                if (valid) sum += n;
            }
        }
        return sum;
    }
    // ...
}

Es wird sicher deutlich, worauf ich hinaus will. Der Lösungsansatz funktioniert zwar, ist aber alles andere als elegant und die Berechnungszeiten für die Schleifendurchläufe sind spürbar.

Ich denke vielleicht an eine rekursive Möglichkeit und hatte auch einen anderen Lösungsansatz für die Variable pattern vom Typ ArrayList, sodass sich die Größe variabel anpasst, je nach Iteration von depth, kam damit aber auch nicht viel weiter.

Hat jemand eine Idee dazu?

Ein Denkanstoß genügt mir an dieser Stelle, kein fertiger Code. :)
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Kgv aller Paare aus einem Array mit n integer berechnen Allgemeine Java-Themen 5
heyluigi Random Integer Array Ausgabe nach Größe sortieren Allgemeine Java-Themen 6
K Array, Int expected, Integer found Allgemeine Java-Themen 5
E Zweidimensionales Array Integer[10 000][10 000] -> out of memory? Allgemeine Java-Themen 4
MQue byte[] Array to Integer Allgemeine Java-Themen 4
J Integer Array Wert vorhanden? Allgemeine Java-Themen 6
H Array nimmt keinen in Integer konvertierten String auf! Allgemeine Java-Themen 26
mrStudent The method append is not applicable for the arguments (Queue<Integer>, Queue<Integer>) Allgemeine Java-Themen 4
O JSON in Integer parsen Allgemeine Java-Themen 5
J Mit Lombok Integer Range prüfen Allgemeine Java-Themen 6
L Variablen Eigenes Objekt wie z.B. einen Integer zuweisen Allgemeine Java-Themen 3
R Datentypen Korrekte integer in Hex ASCII Konvertierung und serialisierung Allgemeine Java-Themen 1
B List<Integer> ist List<Double> ? Allgemeine Java-Themen 6
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
J Eine bestimmte Zahl im Integer ändern Allgemeine Java-Themen 9
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
J Transfer von Integer zwischen zwei Clients - RMI Allgemeine Java-Themen 4
X Integer.numberOfTrailingZeros() Allgemeine Java-Themen 1
HarleyDavidson Best Practice Integer-Zahlenfolge über mehrere Programmstarts Allgemeine Java-Themen 7
B Transferable in String/Integer umwandeln Allgemeine Java-Themen 11
K Input/Output Integer.parseInt() an Textdateien anwenden Allgemeine Java-Themen 2
D Beste Collection für Integer Allgemeine Java-Themen 4
Zettelkasten Double --> Integer Allgemeine Java-Themen 4
M Datentypen ArrayList in Integer konvertieren Allgemeine Java-Themen 3
S Variablen Prüfen ob Number vom Typ Integer, Float, Double, ... ist Allgemeine Java-Themen 2
O Input/Output Textfeld: nur Integer annehmen Allgemeine Java-Themen 9
T int <-> integer, double <-> Double... Allgemeine Java-Themen 2
P JFormattedTextField für durch Semikolon getrennte Integer-Werte gesucht / Regulärer Ausdruck Allgemeine Java-Themen 3
GianaSisters Klassen ArrayList Index Integer int Allgemeine Java-Themen 5
G Datentypen JGoodies Binding und JSpinner mit Integer Allgemeine Java-Themen 2
L Problem mit Integer.parseInt Allgemeine Java-Themen 17
C Benchmark: ArrayList<Integer>, Integer[], int[] Allgemeine Java-Themen 10
Rudolf Aus Collection<Integer> eine Zahl machen Allgemeine Java-Themen 2
O Nach parse von String zu Integer verliere ich Programmablauf! Allgemeine Java-Themen 10
Z Cast von Long zu Integer funktionert nicht Allgemeine Java-Themen 3
T Integer aus InputStream lesen Allgemeine Java-Themen 3
S String[] in Integer umwandeln Allgemeine Java-Themen 16
K Heap-Volllaufen bei ArrayList<Integer> Allgemeine Java-Themen 9
C Character in Integer Allgemeine Java-Themen 12
D Double to Integer - ist das möglich? Allgemeine Java-Themen 3
R Anführungszeichen Integer.valueOf(String).intValue(); Allgemeine Java-Themen 6
H Integer/String Allgemeine Java-Themen 9
J Mit mehrdimensionalen Integer-Arrays arbeiten Allgemeine Java-Themen 17
R Eigene ArrayList vom Typ Short, Integer oder Double Allgemeine Java-Themen 4
G erzeugen von "ArrayList<Integer>[][]" Allgemeine Java-Themen 7
M Integer.parseInt Allgemeine Java-Themen 4
G enum Integer zuweisen Allgemeine Java-Themen 14
G Integer aus String Allgemeine Java-Themen 4
X cannot convert from Object[] to Integer[] Allgemeine Java-Themen 2
B 16Bit Integer aus ByteArray im Little Endian Format Allgemeine Java-Themen 17
O java.lang.NumberFormatException für normalen integer Allgemeine Java-Themen 4
T Integer hhmm addieren Allgemeine Java-Themen 11
MQue Integer in String Allgemeine Java-Themen 2
G Datumswert String in Integer umwandeln Allgemeine Java-Themen 2
P Integer und Bit-operationen Allgemeine Java-Themen 21
M Java 1.4 und Integer Allgemeine Java-Themen 3
G ArrayList<String> to ArrayList<Integer Allgemeine Java-Themen 2
S Integer zu int konvertieren - JUnit Allgemeine Java-Themen 12
M String nach Integer und führende Nullen Allgemeine Java-Themen 6
B Plaintext Integer einlesen und verarbeiten Allgemeine Java-Themen 3
R cast Integer[] zu int[] Allgemeine Java-Themen 2
D byte nach integer? Allgemeine Java-Themen 4
MQue Object in Integer umwandeln Allgemeine Java-Themen 3
H Integer#valueOf(int) bei 1.4 Allgemeine Java-Themen 7
M Datenstrukrue, List<Map<Integer, Map<String, . Allgemeine Java-Themen 2
M Integer in String umwandeln Allgemeine Java-Themen 7
S Object nach Integer umwandeln Allgemeine Java-Themen 13
R Integer will sich nicht lesen lassen! Allgemeine Java-Themen 9
G Umwandlung Byte in Integer Allgemeine Java-Themen 12
M reflection Integer != int ? Allgemeine Java-Themen 3
P int != Integer Allgemeine Java-Themen 3
N Prüfen ob ein String in einen Integer umgewandelt werden kan Allgemeine Java-Themen 4
P Class zu Integer, String, Double etc. Allgemeine Java-Themen 11
S Integer-Zahlen in Excel-Sheet schreiben Allgemeine Java-Themen 10
T JNI: jcharArray: warning: cast to pointer from integer of. Allgemeine Java-Themen 5
R Float richtig in Integer ? Allgemeine Java-Themen 4
T Integer und TextFelder Allgemeine Java-Themen 3
S Integer-splitten für Abfrage. Allgemeine Java-Themen 4
M Index eines Arrays ermitteln und als Integer ausgeben Allgemeine Java-Themen 7
B Integer zählen bzw. speichern Allgemeine Java-Themen 3
H Prüfen, ob es sich um ein Integer handelt Allgemeine Java-Themen 4
J Integer.parseInt funktioniert nicht immer Allgemeine Java-Themen 3
G Nur Integer Werte in JTextField Allgemeine Java-Themen 4
V Typumwandlung Integer, Float etc in String Allgemeine Java-Themen 4
C String in Integer wandeln Allgemeine Java-Themen 17
Fynn29 Liste sortieren ohne Array und ohne vorgegebene Sortierung Allgemeine Java-Themen 24
LucasGlockner Effizienter byte-Zugriff auf ein long[]-Array Allgemeine Java-Themen 8
8u3631984 Frage Performance bei Linked List und Array List Allgemeine Java-Themen 5
M Queue mit einem Array implemetieren Allgemeine Java-Themen 16
M Array Rang eines Elements Allgemeine Java-Themen 4
TheSepp Java bestimmtes Array auf den Wert 0 setzen Allgemeine Java-Themen 32
TheSepp Wie kann man Leerzeichen aus einer Array liste entfernen? Allgemeine Java-Themen 10
B HeapSort für Array of Strings funktioniert nur teilweise Allgemeine Java-Themen 3
noah1407 Array Allgemeine Java-Themen 3
D Methoden Teil-Array mit Maximalwert bestimmen Allgemeine Java-Themen 23
N einem Array Objekte hinzufügen die ihr Array position gespeichert haben Allgemeine Java-Themen 34
N zweidimensionalen Array in dreidimensionalen Array speichern Allgemeine Java-Themen 4
N Schnellste Methode, ein Array durchzugehen? Allgemeine Java-Themen 9
T Objekt Array Aufgabe mit Busdatenbank Allgemeine Java-Themen 2
L Array und Index Allgemeine Java-Themen 26

Ähnliche Java Themen

Neue Themen


Oben