Re: [讨论] 在一个矩阵中找出最多出现次数的向量

楼主: YoursEver (猪是妳)   2016-07-15 14:58:03
※ 引述《popo14777 (草草)》之铭言:
: 小弟的程式如下
: A=[0 0 0 0 0 17 17 19 19 19 17 17 17 17 17]
: B=[0 0 0 0 0 22 22 24 24 24 24 24 24 24 24]
: C=[A;B]
: 0,0 出现5次
: 17,22 出现2次
: 19,24 出现3次
: 17,24 出现4次
: 直向量的个数有15个
: 在C的一个矩阵下挑出次数最多的直向量,且要最少个数,还要不包含零
: 所以挑第11组(17,24)的直向量,并取得11这个数值
: 小弟还有其他矩阵,例如矩阵为11*15(这个范例是2*15)
: 请问大大这样的程式要如何写呢?
: 谢谢
假设你的C是 3-by-N, 2D int array,
(因此不需考虑round off error) <= 这个版本不需考虑round off error
%%%%
01 function [idx, vec] = find_mode_vec( C )
02
03 array_max = max( C(:) );
04 R3_to_R1_mapping = [(array_max+1)*(array_max+1), array_max+1, 1]*C;
05
06 most_freq_entry = mode(R3_to_R1_mapping);
07
08
09 idx = find( R3_to_R1_mapping, most_freq_entry, 'first');
10 vec = C(:, idx);
11
12 end
只适用于 max( C(:) ) 不太大的case,
如果太大, 请另设 R3_to_R1_mapping 所该使用的mapping function.
作者: popo14777 (草草)   2016-07-16 01:12:00
谢谢Y大,我run出来出现这个错误讯息http://imgur.com/Lhx6P3d
作者: name0625 (lawpy)   2016-07-18 12:10:00
Y大还上色!太用心了!

Links booklink

Contact Us: admin [ a t ] ucptt.com