random permutation with no matches to the position
조회 수: 2 (최근 30일)
이전 댓글 표시
Hello everyone,
I have a question. When using randperm function I would like to get only those permutations where no i number appears on the position i in the vector. Does anybody have a suggestion on how to do so?
Example: 1 2 3 4 5
acceptable permutation: 3 1 5 2 4
non-acceptable permutation: 1 3 5 2 4
Thanks a lot in advance!
댓글 수: 2
채택된 답변
추가 답변 (1개)
Jos (10584)
2016년 2월 25일
편집: Jos (10584)
2016년 2월 25일
This specific type of permutation is called a derangement, and there are many methods to generate one. However, it is no so easy to come up with an elegant and fast algorithm.
Take a look at this old thread: http://www.mathworks.com/matlabcentral/newsreader/view_thread/302075#820677
There are several implementations on the file exchange. I will promote my own ;-) http://www.mathworks.com/matlabcentral/fileexchange/30189-randpermfull
참고 항목
카테고리
Help Center 및 File Exchange에서 Random Number Generation에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!