Salesman Problem - Bruteforce Algorithmus

MrXeth

Aktives Mitglied
Hallo, ich sitze gerade an dem Salesman Problem ( Problem des Handlungsreisenden) an einem Bruteforce Algotithmus.
Mein Problem ist, dass ich auf dem Schlauch stehe, wie ich Wege wie A-B-C-D-A und A-D-C-B-A im Vorfeld ausgrenze (ungerichteter Graph).
Mein Code:
Java:
private City[] cities;
   
    @Override
    public City[] getOrder(City[] cities) {
        this.cities = cities;
        City[] weg = new City[cities.length + 1];
        City[] übrStädte = this.cities.clone();
        weg[0] = cities[0];
        übrStädte[0] = null;
       
        City[] comp1, comp2;
        comp1 = rekursion(cities.length - 1, 1, übrStädte.clone(),1 , weg.clone());
       
        for(int i = 1; i < cities.length - 1; i++) {
            comp2 = rekursion(cities.length - 1, i+1, übrStädte.clone(), 1, weg.clone());
            if(compare(comp1, comp2) > 0) {
                comp1 = comp2;
            }
        }
       
        return comp1;
    }
   
   
    private City[] rekursion(int tiefe, int nimmNr, City[] übrStädte,int index, City[] weg) {   
        if(tiefe == 0) {
            weg[weg.length-1] = cities[0];
            for (int i = 0; i < weg.length; i++) {
                System.out.println(weg[i].getName());
               
            }
            System.out.println();
            return weg;
        }
        tiefe--;
        City[] comp1, comp2;
       
        for(int i = 0, j = 0; i < übrStädte.length && j < nimmNr; i++) {
            if(übrStädte[i] != null) {
                j++;
                if(j == nimmNr ) {
                    weg[index] = übrStädte[i];
                    übrStädte[i] = null;
                    index++;
                }
            }
        }
        comp1 = rekursion(tiefe, 1, übrStädte.clone(), index, weg.clone());
        for(int i = 1; i < tiefe; i++) {
            comp2 = rekursion(tiefe, i + 1, übrStädte.clone(), index, weg.clone());
            if(compare(comp1, comp2) > 0) {
                comp1 = comp2;
            }
        }
       
        return comp1;
    }

Die Funktion compare gibt einfach nur einen positiven Wert aus, wenn Stadt 1 > Stadt2 und einen negativen wenn andersherum.

Vielen Dank schonmal für eure Antworten.

Lg MrXeth
 

MrXeth

Aktives Mitglied
Jap, ist für eine Facharbeit. ich möchte da einen Brute Force Algo, ne primitive Heuristik und ne Heuristik, wie man sie in der praxis nutzt haben.
 

MrXeth

Aktives Mitglied
Oder ich schreibe rein, dass man den Brute Force Algorithmus auf diese Weise noch optimieren kann, aber er trotzdem bei großen Mengen keinen Sinn macht.
 

MoxxiManagarm

Top Contributor
Naja du kannst ja erstmal alle Lösungen generieren mit Brut Force und anschließend Rückwärts-Duplikate entfernen. Während des Brut-Force Algorithm würde ich es nicht beachten.
 
X

Xyz1

Gast
Hallo,
also Salesman Brut Force Ansatz wäre zum Bleistift das:
ts1.gif
das:
ts2.gif oder das:
ts3.gif
....und dabei habe ich bei nur 12 Städten die Rückwärts-Duplikate noch nich mit drinne.
 

MrXeth

Aktives Mitglied
Code:
package travelingSalesmanProblem;

import map.City;

public class BruteForce extends Method {
   
    private City[] cities;
   
    @Override
    public City[] getOrder(City[] cities) {
        this.cities = cities;
        City[] weg = new City[cities.length + 1];
        City[] übrStädte = this.cities.clone();
        weg[0] = cities[0];
        übrStädte[0] = null;
        int limit = cities.length - 1;
       
        City[] comp1, comp2;
        comp1 = rekursion(cities.length - 1, 1, übrStädte.clone(),1 , weg.clone(), cities.length-1);
       
        for(int i = 1; i < cities.length - 2; i++) {
            limit --;
            comp2 = rekursion(cities.length - 1, i+1, übrStädte.clone(), 1, weg.clone(), limit);
            if(compare(comp1, comp2) > 0) {
                comp1 = comp2;
            }
        }
       
        return comp1;
    }
   
   
    private City[] rekursion(int tiefe, int nimmNr, City[] übrStädte,int index, City[] weg, int limit) {   
        if(tiefe == 0) {
            weg[weg.length-1] = cities[0];S
            return weg;
        }
        tiefe--;
        limit  = tiefe;
        City[] comp1, comp2;
       
        for(int i = 0, j = 0; i < übrStädte.length && j < nimmNr; i++) {
            if(übrStädte[i] != null) {
                j++;
                if(j == nimmNr ) {
                    weg[index] = übrStädte[i];
                    übrStädte[i] = null;
                    index++;
                }
            }
        }
        comp1 = rekursion(tiefe, 1, übrStädte.clone(), index, weg.clone(), tiefe);
        for(int i = 1; i < limit; i++) {
            comp2 = rekursion(tiefe, i + 1, übrStädte.clone(), index, weg.clone(), tiefe);
            if(compare(comp1, comp2) > 0) {
                comp1 = comp2;
            }
        }
       
        return comp1;
    }
   
    private int compare(City[] c1, City[] c2) {
        double ci1 = 0, ci2 = 0;
        for(int i = 1; i < c1.length; i++) {
            ci1 += dist(c1[i-1], c1[i]);
        }
        for(int i = 1; i < c2.length; i++) {
            ci2 += dist(c2[i-1], c2[i]);
        }
        return (int) (ci1 - ci2);
    }
   
}

das ist jetzt mein code, falls noch jemand anderes hilfe braucht ^^

am anfang lasse ich den letzten kinderbaum einfach direkt weg.

dann setze ich limits, also wie oft beim ersten kinderbaum das nächste aufgerufen wird.
da habe ich den zusammenhang gefunden, dass ich einfach immer beim nächsten aufrufen, die nächste Stadt bzw. die nächsten 2 städte bei einer anzahl von 5 Städten löschen kann.

Selbstverständlich muss der code noch laufzeittechnisch aufgepimpt werden, funktioniert so aber schon einmal.
 

mrBrown

Super-Moderator
Mitarbeiter
Puh, sicher, dass der Code so korrekt arbeitet?

Bevor du da irgendwas an der Laufzeit machst, würde ich da erstmal an der Lesbarkeit arbeiten, da liegt doch so einiges im Argen...
 
X

Xyz1

Gast
Ok ein einfacher Brute force Ansatz ohne Optimierung mit 5 alphabetisch sortierten Städten macht genau das:

ts4.gif

habe mal den Backgrund grau und jeweils 1 Sekunde, wie man sieht dauert es ewig
 
X

Xyz1

Gast
@mihe7 ;)
Sage mir mal wie ich das aufbauen soll ich schreibe gerad eine Art winziges Framework dafür:
Java:
nods.add(new Nod(1, 'a', new Point(700 / 2, 550 / 4)));
drawItInternal(new boolean[nods.size()], new ArrayList<>(), gsw);
nods.add(new Nod(2, 'b', new Point(50, 50)));
drawItInternal(new boolean[nods.size()], new ArrayList<>(), gsw);
nods.add(new Nod(3, 'c', new Point(50, 500)));
drawItInternal(new boolean[nods.size()], new ArrayList<>(), gsw);
nods.add(new Nod(4, 'd', new Point(650, 50)));
drawItInternal(new boolean[nods.size()], new ArrayList<>(), gsw);
nods.add(new Nod(5, 'e', new Point(650, 500)));
drawItInternal(new boolean[nods.size()], new ArrayList<>(), gsw);

tsp(0, new boolean[nods.size()], new ArrayList<>(), gsw);

.... oder die Bundesländer München, Frankfurt, Hesswn usw. usf.?
 

mrBrown

Super-Moderator
Mitarbeiter
Sage mir mal wie ich das aufbauen soll ich schreibe gerad eine Art winziges Framework dafür:
Im Idealfall so aufgebaut, dass man es auf den ersten Blick verstehen kann.

.... oder die Bundesländer München, Frankfurt, Hesswn usw. usf.?
Abgesehen davon, dass München & Frankfurt keine Bundesländer sind, sind Bundesländer eher ungeeignet:
Bayern - Hessen -> gemeinsame Grenze, keine Entfernung.
Hessen - Niedersachen -> gemeinsame Grenze, keine Entfernung.
Niedersachen - Schleswig-Holstein -> gemeinsame Grenze, keine Entfernung.
Bayern - Schleswig-Holstein -> ziemlich weit entfernt.
 

MrXeth

Aktives Mitglied
Puh, sicher, dass der Code so korrekt arbeitet?

Bevor du da irgendwas an der Laufzeit machst, würde ich da erstmal an der Lesbarkeit arbeiten, da liegt doch so einiges im Argen...

Habe etwas dran gearbeitet, aber was meinst du denn zB genau? Also mit Zeug, wie Point, Lists usw arbeite ich bei schulprojekten ungerne, da es hier nicht zwingend erforderlich ist und unser LK noch nicht so weit ist
 

mrBrown

Super-Moderator
Mitarbeiter
Dies zB:
Java:
        City[] übrStädte = this.cities.clone();
        weg[0] = cities[0];
        übrStädte[0] = null;

oder dies:
Java:
private City[] rekursion(int tiefe, /*... ,*/ int limit) { 
        /*
        ...
        */
        tiefe--;
        limit  = tiefe;

Das ist so das auffälligste an völlig unsinnigem Code...


Oder diese Schleife:
Java:
for(int i = 0, j = 0; i < übrStädte.length && j < nimmNr; i++) {
            if(übrStädte[i] != null) {
                j++;
                if(j == nimmNr ) {
                    weg[index] = übrStädte[i];
                    übrStädte[i] = null;
                    index++;
                }
            }
        }
Ich bin ehrlich gesagt immer noch nicht sicher, ob ich verstanden hab, was du da wirklich machen möchtest...
Es sieht aus nach nimmNr'ste Stadt aus übrStädte entfernen und an weg anhängen, aber das lässt sich kaum besser da drin verstecken...
 

MrXeth

Aktives Mitglied
Das erste hat den sinn, dass es nur flache kopien sind. Das Zweite hat was mit dem rausschneiden zu tun und das 3te hast du ja bereits gesagt
 

mrBrown

Super-Moderator
Mitarbeiter
Das erste hat den sinn, dass es nur flache kopien sind
Stimmt, sieht man mal, wie unübersichtlich das ist, wenn sowas nicht mal auffällt ;)

Das Zweite hat was mit dem rausschneiden zu tun
Du übergibst 2 Variable, um die eine dann direkt mit der anderen zu überschreiben -das hat einfach keinen Sinn (außer Verwirrung zu schaffen).

das 3te hast du ja bereits gesagt
und warum schreibst du das dann so obfuskiert dahin? ;)
 

MrXeth

Aktives Mitglied
Woow danke dass du mich nochmal drauf hingewiesen hast, das limit = tiefe muss weg und dann in der 2ten forschleife muss anstatt limit limit - 1 stehen

Also ich hab mir mal wieder was schlaues ausgedacht und es durch dummheit unnütz gemacht
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
K Methoden Traveling Salesman Tour Allgemeine Java-Themen 3
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben