Shuffle vector with constraints
Ältere Kommentare anzeigen
Hi,
I have an array of 50 1's, 50 2's, etc up to 50 8's. I would like to shuffle them with the constraint that two consecutive numbers cannot be the same. I tried several options but most are very cpu intensive or did not yield a good result. Are there computation efficient solutions to this problem?
1 Kommentar
Azzi Abdelmalek
am 14 Jan. 2014
This is not enough as information. Because you can set them for example [1 2 3 1 2 3 1 2 3 . . .]
Akzeptierte Antwort
Weitere Antworten (3)
Mischa Kim
am 14 Jan. 2014
Bearbeitet: Mischa Kim
am 14 Jan. 2014
Since I do not know what techniques you have tried, here's (another) one? Start with sorting the 1's, 2's, etc. in matrix form, i.e.,
1 1 1 1...
2 2 2 2...
3 3 3 3...
and perform permutations on the individual columns (e.g using randperm). Based on the entry of the last row in the first column randomly pick a column vector with a different first row entry and make it the new second column. Using this process work your way through all the columns (you might have to do some more permutations towards the final columns). Once done, transpose and concenate all of the column vectors.
Pieter
am 14 Jan. 2014
0 Stimmen
1 Kommentar
Mischa Kim
am 14 Jan. 2014
Bearbeitet: Mischa Kim
am 14 Jan. 2014
Hello Pieter,
- Understood. I used the permutation for shuffling with a certain level of randomness (while satisfying the constraint).
- You can still use the approach outlined above by randomly tossing in the 30 9's into the vector at the end.
Pieter
am 14 Jan. 2014
0 Stimmen
Kategorien
Mehr zu Entering Commands finden Sie in Hilfe-Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!