Personenaufteilung bei Konferenz in mehreren Runden
#11
Hallo Tafelsalz,


hier ein Vorschlag, hm... der eigentlich Brute-force ist, aber das klingt nicht so gut, also anders formuliert.

Es gibt 8 Fakultät Möglichkeiten die Reihenfolge der 8 Tische auszuwählen. Der beigefügte Code errechnet zuerst alle Möglichkeiten (42.320) und trifft dann für die Teilnehmen, ob 40, 50 oder auch mehr ist egal, eine Zufallsauswahl.

Es ist möglich, aber im Code nicht implementiert, zu prüfen, ob alle genannten Bedingungen erfüllt sind.

Bedienung: einmal mit strg-k die Kombinationen errechnet (ca. 2-8 Sekunden, je nach Rechner), dann mit strg-p die Laufwege der Teilnehmer bestimmen.

mfg

Fennek


Angehängte Dateien
.xls   Tafelsalz.xls (Größe: 38,5 KB / Downloads: 11)
Top
#12
Hallo Fennek,

ich habe mir die Beispieldatei angesehen und suche nach dem Mauseloch wo ich mich verstecken kann.
Das ist eine Makro Sprache die ist mir mehr als 100x zu hoch, da verstehe ich buchstaeblich garnichts. 

Sorry, ich weiss nicht ob der Frager das Ergebniss begreift.  Da happerts bei mir völlig an der Logik !!
Ich sehe zwar Person P1 mit:  FBGCHDEA  und P2 mit:  ACFHBGED   aber was bedeutet es konkret????

Ich erkenne keine Tische, sehe nicht welche Person an welchem Tisch sitzt, und was ist mit den 4 Runden???
Ich verweise höflich auf die Aufgabenstellung in der ersten Anfrage.  Die war die Basis meiner Überlegungen.
Ich weiss nicht wie man ein Zitat schreibt, deshalb kopiere ich mai die Anfrage:


Zitat:Wir haben die Teilnehmer TN1 bis TN40

Wir haben die Tische A bis E
Es gibt 4 Runden

In der 1. Runde 
- verteilen sich die 40 Teilnehmer gleichmäßig auf die Tische  A, B, C, D, E
-  es stehen also 8 Teilnehmer an Tisch A

In der 2. Runde
 sollen die Teilnehmer von Tisch A gleichmäßig auf die Tische B, C, D, E aufgeteilt werden.  
Es kommen also maximal 2 Personen in der nächsten Runde in die gleiche Gruppe.
Das gleiche passiert mit den Teilnehmern die zuvor an den anderen Tischen waren.
Es darf kein Teilnehmer den gleichen Tisch zwei Mal besuchen. 

Bei deiner Lösung sehe ich nur 8 Buchstaben, und nur in einer Spalte. Ich erkenne daraus bei aller Liebe
zu deiner echt bewunderswerten Arbeit keine erkennbare Zuordnung wie die Personen verteilt werden??
Vielleicht erklaerst du uns das mal. An dein Programm gehe ich mit meinen Excel 97 Wissen nicht dran!
Das ist für mich höhere Mathematik. Ich besitze nur Volksschule Wissen, kann schon bis drei zaehlen.
Aber als gelernter Elektroniker denke ich in logischen Zuordnungen. Die ist mir hier nicht ersichtlich.

mfg  Gast 123
Top
#13
@Gast123

Die Argumente sind richtig, die Aufgabenstellung mit den 4 Runden habe ich einfach ignoriert. Aber wenn A-H die Tische markieren, dann können die ersten vier Buchstaben als "Laufweg" für die jeweilige Person interpreteiert werden.
Beispiel: Person 1: AGDB bedeutet, dass Person 1 zuerst zum Tisch A, dann G usw geht.

Es ist möglich, diese Laufwege zu prüfen und gegebenfalls zu modifizieren, oder einfach eine neue Zufallsauswahl zu rechnen. Das Ansatz ist völlig anders, aber vielleicht führt er auch zum Ziel.

mfg
Top
#14
Hi,

(27.05.2016, 23:37)Fennek schrieb: Das Ansatz ist völlig anders, aber vielleicht führt er auch zum Ziel.

Das ist eine super Vorgehenweise!
Aber ich muß zugeben, ich verstehe das große Makro (iFaku) auch noch nicht. Kombinatorik ist bei mir schon bei weitem zu lange her und die Umsetzung als Makro habe ich noch nie gesehen.

Kannst Du Dir bitte die Zeit nehmen und das Makro Schritt für Schritt erläutern, damit ich verstehe, was welche Zeile macht? Dann kann ich es vielleicht auch für andere Aufgaben benutzen und anpassen.
Immerhin kann ich es so ändern, daß die Anzahl der Tische änderbar ist.

Sehr schön kann ist auch zu sehen, daß mein Rechner ein ganzes Stück langsamer ist, da die Kombinatorik bei mir 10,6 - 10,8 Sekunden braucht. :)
Immerhin habe ich es hinbekommen, daß nur 5 Tische benutzt werden.

ich habe es mir noch mit ein bißchen Erläuterung versehen und die Tische aufgesplittet:

Personen
ABCDEFGHIJKLMNOPQR
1Kombinationen starten mit strg-k (warten, bis msgbox erscheint)
2Personen zuordnen mit strg-p
3Anzahl Teilnehmer40Buchstaben sind die Reihenfolge der Tische, an denen die Personen stehen.
4
5PersonenAufgabe:Runde 1Runde 2Runde 3Runde 4Runde 5Runde 6Runde 7Runde 8
6TN 1CBEADWir haben die Teilnehmer TN 1 bis TN 40CBEAD
7TN 2EDACBEDACB
8TN 3CBEDAWir haben die Tische A bis ECBEDA
9TN 4CDEABEs gibt 4 RundenCDEAB
10TN 5DACEBDACEB
11TN 6EBCADIn der 1. Runde EBCAD
12TN 7BDACE'- verteilen sich die 40 Teilnehmer gleichmäßig auf die Tische  A, B, C, D, EBDACE
13TN 8BDACE'-  es stehen also 8 Teilnehmer an Tisch ABDACE
14TN 9ABDECABDEC
15TN 10ABDCEIn der 2. RundeABDCE
16TN 11BEDCA sollen die Teilnehmer von Tisch A gleichmäßig auf die Tische B, C, D, E aufgeteilt werden.  BEDCA
17TN 12CABDEEs kommen also maximal 2 Personen in der nächsten Runde in die gleiche Gruppe.CABDE
18TN 13DBAECDas gleiche passiert mit den Teilnehmern die zuvor an den anderen Tischen waren.DBAEC
19TN 14ABDCEEs darf kein Teilnehmer den gleichen Tisch zwei Mal besuchen. ABDCE
20TN 15CDEABCDEAB
Schriftart wird in dieser Tabelle nicht dargestellt

verwendete Formeln
Zelle Formel Bereich N/A
K6:K20=LINKS(B6;1)
L6:R20=TEIL($B6;SPALTE(B$1);1)

Schriftformate
Zelle Rot Grün Blau Color Stil Unterstreichung Effekte Durchgestrichen Schriftart
A3, A5,  D5,   K5:R5 Fett  
D6, D8: D9,   D11: D13,      D15: D19 Kursiv  
Zellen mit Schriftformatierung automatisch werden nicht dargestellt
Excel-Inn.de
Hajo-Excel.de
XHTML-Tabelle zur Darstellung in Foren, einschl. der neuen Funktionen ab Version 2007
Add-In-Version 21.07 einschl. 64 Bit

Top
#15
@Rabe

Der Code ist mein Versuch, die www.herber.de/excelformeln und bitte suchen ... Nr 325 in vba zu übersetzen. Sicher sehr holprig programmiert, aber es funktioniert. Ich sah das eher als Programmierübung an.

In einem anderen Forum bekam ich danach einige Tipps über andere Ansätze, aber die muss ich mir (am nächsten veregneten Sonntag) noch genauer ansehen.

mfg

http://ms-office-forum.net/forum/showthr...p?t=331801
Top
#16
Hi,

(28.05.2016, 12:06)Fennek schrieb: Sicher sehr holprig programmiert

mit meiner bisherigen wenigen Erfahrung mit VBA (Makrorekorder benutzen, Makros bereinigen, verallgemeinern oder versuchen, fertige Makros nachzuvollziehen) sieht mein Code wohl immer deutlich holpriger aus.
:100:



PS: Kommst Du eigentlich zum Exceltreffen?
Antwort A: Schön!
Antwort B: Schade! Warum nicht?
Top
#17
Halo Rabe, hallo Fennek

wenn ich solche Text lese wie:  Makro (iFaku) und Kombinatorik  habe ich das Gefühl ich lebe auf einem anderen Planeten.
Das ist mir derart zu hoch, das ich es nicht einmal verstehen will  (geschweige denn kann!)   Dafür bin ich einfach zu alt.

Ich habe mir die Zerlegung  des Ergebnisses in der Tabelle angesehen, jetzt erkennt man wenigstens etwas.
Ich weiss aber nicht ob ihr die  -Shift Funktion-  mir bekannt als Serielles Schieberegister  (CD4015?) erkannt habt.
Die Teilnehmer der 1. Runde sollen ja von Tisch A jeweils zu zweit auf die Tische  B-E  verteilt werden. = Shiften
Das Shiften konnte ich in der Kombitonk Lösung nicht sehen. Gehört aber nun mal zur Aufgabenstellung.

Das geht noch bis zu 40 Teilnehmer, versagt aber bei 45-50 Personen! Ich erkannte schnell in meiner Makro Shift Funktion 
das die letzten Teilnehmer von Tisch A wieder an Tisch A kamen!  Ich verschob Person 9 an Tisch C, Person 10 an Tisch D.
Woran mein Makro dann aber scheiterte war die Aufgabe, keine doppelten Teilnehmer, die vorher einmal zusammen sassen.
Daran bin ich gescheitert. Das hat mich sehr gewurmt.

Es gab diesen Fall aber schon einmal über 10 Runden mit über 80 Personen. Aber dabei laeuft sich der Zufallgenerator tot.
Ich habe keine Möglichkeit zu begreifen in wieweit das Kombitonk Makro sowohl Shiften kann, wie auch doppelte TN ausfiltert??
Solche Aufgaben wird es in aehnlicher Form immer wieder geben. Eine echte Lösung würde mich interessieren. Bei (Faku) und
Kombitonk fehlt mir aber das fachliche Wissen das Makro nachvollziehen zu können. Daraus mache ich aıuch keinen Hahl.

Das sind so Knobbel Threads an denen man sich echt die Zaehne ausbeissen kann. Klingen harmlos, ist es aber nicht!

mfg  Gast 123 
 
Top
#18
Hi,

(28.05.2016, 14:04)Gast 123 schrieb: Ich habe keine Möglichkeit zu begreifen in wieweit das Kombitonk Makro sowohl Shiften kann, wie auch doppelte TN ausfiltert??

Das Wissen fehlt mir auch, bzw. ist 30 Jahre her.

Das hat Fennek ja geschrieben, daß das "auf Doppelte prüfen" und "shiften" noch nicht eingebaut ist.
Top
#19
Hallo ins Forum,

vielen Dank für all eure Mühen - insbesondere an Gast123.

Seine Lösung hat mich am meisten überzeugt und funktioniert für 40 Personen ziemlich gut.
Herzlichen Dank an dieser Stelle!

Ich sehe diese Aufgabe hiermit als erledigt an.

Liebe Grüße,
tafelsalz
Top


Gehe zu:


Benutzer, die gerade dieses Thema anschauen: 2 Gast/Gäste