![]() |
Matlab nchoosek问题
我的问题与Matlab有关。存在一个名为nchoosek([vector],integer)的函数。通过使用此函数,我想获得给定向量的所有2元素组合。 (即nchoosek([1:10000,2]))。如Matlab文档中所述,这非常慢。
问题是:“有没有更快的方法来完成相同的工作?”。 谢谢您的宝贵时间,我非常感谢您的努力。 [B]回答:[/B] 如果只需要2个元素的组合,则可以使用[URL="http://www.mathworks.com/help/techdoc/ref/ndgrid.html"]NDGRID[/URL] 。请注意,直到N所有两个元素组合都需要N^2值,因此,如果Matlab开始分页,则过程将很慢。 N = 100; [xx,yy] = ndgrid(1:N,1:N); allCombinations = [xx(:),yy(:)]; 请注意,该功能[URL="http://www.mathworks.com/help/techdoc/ref/ndgrid.html"]NDGRID[/URL]从显著不同[URL="http://www.mathworks.es/es/help/matlab/ref/nchoosek.html"]nchoosek[/URL] 。前者返回一个具有所有可能的N ^ 2组合的双行向量,而后者则省略了两次相同元素的组合,以及仅改变顺序的组合。导致仅(N ^ 2-N)/ 2个行元素。 [url=https://stackoverflow.com/questions/5116928]更多&回答...[/url] |
所有时间均为北京时间。现在的时间是 02:58。 |
Powered by vBulletin
版权所有 ©2000 - 2025,Jelsoft Enterprises Ltd.