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

楼主: celestialgod (天)   2016-07-15 01:01:36
※ 引述《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)
: 请问大大这样的程式要如何写呢?
: 谢谢
我不知道有没有更好的方法XD
好读版:http://pastebin.com/hANz1W33
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的列
idxFilterZeros = find(any(bsxfun(@ne, C, zeros(1, size(C, 2))), 2));
C2 = C(idxFilterZeros, :);
% 找出unique的列
[output, idx1, idx2] = unique(C2, 'rows');
% 用unique列的index去算frequencies
uni_idx = sort(unique(idx2));
% 计算unique列的frequencies
count = histc(idx2, uni_idx);
% 找到最大frequency的列
[~, maxIdx] = max(count);
% 叫出有最大frequency的列
out = C2(find(idx2 == uni_idx(maxIdx), 1, 'first'), :);
outIdx = idxFilterZeros(idx1(maxIdx));
已更正,outIdx就是所求
有问题再问吧XD
另外麻烦不要私信问,一切问题留在板上处理,谢谢
作者: popo14777 (草草)   2016-07-15 09:26:00
谢谢C大,小弟我要11这个数值要如何取得呢?因为后续的程式需要输入挑出这组的数字11其实小弟最主要只是要得到11这个数值就好,不用列出17,24没关系,谢谢
作者: name0625 (lawpy)   2016-07-15 10:02:00
就index啊,C2括号内的find那段就可以
作者: popo14777 (草草)   2016-07-15 13:31:00
n大,在C2括号内哪边打index呢? 谢谢
楼主: celestialgod (天)   2016-07-16 10:13:00
晚点再试试看,我没注意到要11这个数值应该是idx=find(any(bsxfun(@ne, C, zeros(1, size(C, 2))));idx(maxIdx)试试看,不行再跟我说目前手边没电脑可以测试
作者: popo14777 (草草)   2016-07-16 15:03:00
谢谢C大,但还是没有显示11..谢谢C大,太感谢你了...

Links booklink

Contact Us: admin [ a t ] ucptt.com