Suche Permutationsalgo

chris_L_1980

Mitglied
Hallo,
ich suche einen bestimmten Permutationsalgorithmus, leider ist mein Einfallsreichtum wie man den implementieren kann im moment bei 0 :(

Also ich habe eine Zeile der länge n und eine beliebige anzahl an blöcken, die in diese Zeile reinpassen mit mindestens einer Zelle abstand.
Z.B. hat die Zeile eine länge von 5, und ich hab 2 Blöcke mit der länge "1" und "2". dann gäbe es als möglichkeiten(1 für Block, 0 für frei):
10110
10011
01011

Hierfür such ich einen Algorithmus, der als Parameter die Zeilenlänge und ein int-Array mit den Blocklängen bekommt.
 

nrg

Top Contributor
also vllt liegt es an meinem Zustand, aber ich kann grad noch nicht wirklich nachvollziehen, was du willst ;)
 

Landei

Top Contributor
Für alle möglichen Positionen des ersten Blocks: Block und "umgebende" Leerzeichen positionieren, mit den restlichen Blöcken und dem entsprechend verkürzten Array das ganze wiederholen...
 

Marco13

Top Contributor
Man könnte sich da verschiedene Ansätze überlegen... Wenn es nicht DER optimale sein muss, könnte man relativ "einfache" Workarounds suchen, wie z.B. alle Reihenfolgen für die Blöcke bestimmen, und dann überprüfen, ob das nach dem Einfügen der benötigten Leerzeichen noch passt. Dass die Leerzeichen am Anfang und am Ende "optional" sind, und dass ein Leerzeichen rechts von A und ein Leerzeichen links von B nicht ZWEI Leerzeichen sind, sondern EINS (eben zwischen A und B) macht das Problem ansonsten vermutlich ziemlich fummelig...
 

Landei

Top Contributor
Java:
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.List;

public class BlockAlgo {

    public static List<List<Integer>> solutions(int length, int... blocks) {
        List<List<Integer>> result = new ArrayList<List<Integer>>();
        if (blocks.length == 0) {
            result.add(Collections.nCopies(length, 0));
        } else {
            boolean last = blocks.length == 1;
            int minLength = -1;
            for(int b : blocks) {
                minLength += b + 1;
            }
            for(int start = 0; start <= length - minLength; start++) {
                List<Integer> initial = new ArrayList<Integer>();
                initial.addAll(Collections.nCopies(start, 0));
                initial.addAll(Collections.nCopies(blocks[0], 1));
                if(! last) {
                    initial.add(0);
                }
                for(List subList : solutions(length - start - blocks[0] -
                        (last ? 0 : 1),
                        Arrays.copyOfRange(blocks, 1, blocks.length))) {
                    List<Integer> list = new ArrayList<Integer>();
                    list.addAll(initial);
                    list.addAll(subList);
                    result.add(list);
                }
            }
        }
        return result;
    }

    public static void main(String[] args) {
        for(List<Integer> list : solutions(23, 1, 3, 2, 5, 4)) {
           System.out.println(list);
        }
    }
}
 

chris_L_1980

Mitglied
Hallo,
verzeiht das ich mich so spät melde, aber gestern war wieder so ein Tag, an dem man froh ist, wenn man endlich nach Hause kommt...

also erstmal vielen Dank für den algo. funktioniert wunderbar und macht genau das, was er machen soll :)
hab allerdings noch ein paar kleine verständnisfragen.
1. Steht minLength für die am weitesten rechts liegende Anfangsposition des ersten blocks?
2. und warum ist der wert -1 am anfang?

ansonsten hab ich denke ich alles ziemlich genau verstanden und bedanke mich nochmal :)
 

Landei

Top Contributor
Hallo,
verzeiht das ich mich so spät melde, aber gestern war wieder so ein Tag, an dem man froh ist, wenn man endlich nach Hause kommt...

also erstmal vielen Dank für den algo. funktioniert wunderbar und macht genau das, was er machen soll :)
hab allerdings noch ein paar kleine verständnisfragen.
1. Steht minLength für die am weitesten rechts liegende Anfangsposition des ersten blocks?
minLength ist die minimale Länge, bei der ich alle Blöcke noch unterbringen kann.

2. und warum ist der wert -1 am anfang?
Weil der "rechteste" Block rechts neben sich keine Leerstelle braucht.
 
Zuletzt bearbeitet:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
M Binäre Suche Allgemeine Java-Themen 6
M geometrische Suche Allgemeine Java-Themen 8
S Programm schreiben, das mir aufgrund von Schlagwörtern, die ich im Internet suche, relevante Themen sofort anzeigt. Allgemeine Java-Themen 1
I HTML / XHTML Seite nach Excel exportieren. Suche Lib Allgemeine Java-Themen 12
W Suche Ursache für NPE - woher kommt sie? (Hilfe beim Debugging) Allgemeine Java-Themen 19
W Collections Suche Collection, um Strings mit Indizees versehen Allgemeine Java-Themen 47
O Suche Scripter für alt:V Project! Allgemeine Java-Themen 0
D Suche Quellcode! Allgemeine Java-Themen 8
O Suche Unterstützung für ein OpenSource-Projekt (grafischer Editor) Allgemeine Java-Themen 13
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J Suche Alternative zu Jasper Reports Allgemeine Java-Themen 4
W Collections Suche etwas Sorted-List-Artiges...hat jemand eine Idee? Allgemeine Java-Themen 13
M Suche Alternative zu JFreeChart Allgemeine Java-Themen 11
S Warmup für Lineare-Suche mit Zeitmessung Allgemeine Java-Themen 2
K OOP Suche Hilfe + Erklärung für eine Hausaufgabe Allgemeine Java-Themen 1
B Suche nach einem Testprogramm für meine BA Allgemeine Java-Themen 0
D Objekt-Suche mit mehreren optionalen Parametern Allgemeine Java-Themen 6
A NetBeans Suche Programmierer für eine Belegarbeit Allgemeine Java-Themen 11
O Suche größeres Beispiel für WebserverAnwendung mit Java Allgemeine Java-Themen 2
G Google-Suche ist nicht auslesbar?! Allgemeine Java-Themen 18
M Suche aktuelle Apache Poi Bibliothek zum Einbinden in mein Programm Allgemeine Java-Themen 2
L Suche nach CalDav Server API Allgemeine Java-Themen 0
HarleyDavidson Best Practice Suche "Container" für Modulapplikationen Allgemeine Java-Themen 0
S Suche Konzept: Korrektheit des Aufrufers feststellen Allgemeine Java-Themen 7
KaffeeFan Methoden Suche Methode um Programm kurz warten zu lassen Allgemeine Java-Themen 22
B Suche geeignete Datenstruktur Allgemeine Java-Themen 5
L Erste Schritte Suche Java Wiki System? Allgemeine Java-Themen 5
L Suche Geräte für Java SE Embedded Allgemeine Java-Themen 0
S Rekursive Suche in einem Netz Allgemeine Java-Themen 5
F Über Java Google Suche nutzen Allgemeine Java-Themen 11
A Suche Android Programmierer Allgemeine Java-Themen 0
W Suche Framework zur Prüfung von IPv4 und IPv6 Allgemeine Java-Themen 2
A Java - Suche nach Datensatz mit DateChooser Allgemeine Java-Themen 0
S Pattern.Match Suche: For Schleife einbinden und in Liste schreiben Allgemeine Java-Themen 3
M Suche Framework/API für Monitoring-Anwendung Allgemeine Java-Themen 3
F Suche kostenlose GUI für Eclipse Allgemeine Java-Themen 10
H Suche mit Wildcards und boolschen Operatoren Allgemeine Java-Themen 4
B Suche passende Datenstruktur für 2 Einträge Allgemeine Java-Themen 19
A Binäre Suche im Array mit StackOverflowError Allgemeine Java-Themen 3
T Verkettete Suche Allgemeine Java-Themen 6
S RxTx - langsame Port suche Allgemeine Java-Themen 3
D Suche Matrix Libraries Allgemeine Java-Themen 11
S Suche Dependency Injection Container Allgemeine Java-Themen 6
J Suche: Tool zum Auffinden gleichnamiger Klassen (Name und Package gleich) in unteschiedlichen JARs Allgemeine Java-Themen 5
BinaryLogic Input/Output Suche Wörterbuch-Datei Einzahl/Mehrzahl Allgemeine Java-Themen 2
A Suche Algorithmus zum Erstellen eines planaren Graphen Allgemeine Java-Themen 5
D Suche Librarys ähnlich datatables.net + Login Allgemeine Java-Themen 3
Gossi Threads Suche ein (einfaches) Beispiel Allgemeine Java-Themen 5
P Erste Schritte Suche in ArrayList mit Maps Allgemeine Java-Themen 4
F Suche Performanceoptimierung bei Stringsortierung Allgemeine Java-Themen 51
B Suche Datenquelle für lizenz-informationen Allgemeine Java-Themen 5
J Lucene suche in Json (CouchDB) Allgemeine Java-Themen 2
X Suche Softwareimplementierung von Cryptographischen Algorithmen Allgemeine Java-Themen 3
S Suche Tipps für Einstieg in JavaCC Allgemeine Java-Themen 2
R Suche in logfiles mit Lucene / Solr Allgemeine Java-Themen 2
P Suche Datenstruktur Allgemeine Java-Themen 2
M Suche Java-Projekt zum Thema Elektrotechnik Allgemeine Java-Themen 6
F Suche Begriff Allgemeine Java-Themen 2
hdi Suche Icon-Sammlung Allgemeine Java-Themen 7
G Suche "richtiges" Framework/Library Allgemeine Java-Themen 14
slawaweis Suche Klassen für Event Managment und Time Allgemeine Java-Themen 2
P Probleme mit wikipedia quellcode zur binären Suche Allgemeine Java-Themen 6
E Suche nach Foto-Dummy Allgemeine Java-Themen 8
B Suche Paket zum auslesen von Metadaten von Bildern. Allgemeine Java-Themen 4
N suche globale Tastenabfrage Allgemeine Java-Themen 6
P SUCHE: gute Geo Library (freeware) Allgemeine Java-Themen 2
P Suche performante PDF Library Allgemeine Java-Themen 20
data89 Bilder mit Java prüfen - suche dringend Hilfe Allgemeine Java-Themen 8
faetzminator Regex zur Suche von "value-losen" Attributen in HTML Tags Allgemeine Java-Themen 7
S Suche im JTree nach Neuaufbau Allgemeine Java-Themen 4
W Problem bei der Suche (binarySearch) vom deutschen Sonderzeichen "ß" im einem Array Allgemeine Java-Themen 6
D Suche nach passender Datenstruktur Allgemeine Java-Themen 4
S suche library die diagramme darstellen kann Allgemeine Java-Themen 2
T Suche Anhaltspunkt für plattformübergreifende, "unique machine id" ... Allgemeine Java-Themen 12
P WebSerive Suche Allgemeine Java-Themen 15
hdi Suche nach Begriff aus der Programmierung Allgemeine Java-Themen 11
X Suche Java Klasse die Feiertage berechnen kann Allgemeine Java-Themen 2
B suche Deutsche Übersetzung für neuste Eclipse Version Allgemeine Java-Themen 6
Daniel_L Suche nach ganzen Wörtern (wholeword) in Strings? Allgemeine Java-Themen 4
G Regex-Suche nach Worten Allgemeine Java-Themen 3
Antoras Suche Projektarbeit für Gruppe mit 3 Leuten Allgemeine Java-Themen 5
G Perfomante Suche in grosser Datei Allgemeine Java-Themen 6
T Suche Tool Allgemeine Java-Themen 11
D Suche sowas wie Map nur für mehrere Werte Allgemeine Java-Themen 13
D Suche Hilfe zum Rechnerübergreifenden Dateizugriff. Allgemeine Java-Themen 3
M suche speziellen Sortieralgorithmus Allgemeine Java-Themen 3
E javax.comm: Suche eine open source Alternative zu rxtx Allgemeine Java-Themen 8
J Suche regex-Pattern fuer Liste von Zahlen zwischen 0-100 Allgemeine Java-Themen 6
T Suche den großen Calendar Thread ! Allgemeine Java-Themen 2
P Suche Benis IP/Netzwerkadresse JTExtField Allgemeine Java-Themen 2
J Suche Doku um generischen Code zu erstellen. Allgemeine Java-Themen 9
G suche Property alternative Allgemeine Java-Themen 4
C Fehler im Quellcode. Suche in einem Baum Allgemeine Java-Themen 3
S Suche Pendant zu einem VB Befehl Allgemeine Java-Themen 2
T Suche gute JAVA Steuerelemente Allgemeine Java-Themen 2
V Suche RegEx zu (gelöstem) Problem Allgemeine Java-Themen 3
B Suche Browser-Control Allgemeine Java-Themen 4
G Suche Programmierumgebung mit Appletviewer Allgemeine Java-Themen 16
G Suche kostenlosen c++ to java converter. Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben