假设我有:
m = [1,2,3;1,4,5;6,4,7]
我想得到一个包含矩阵m
中元素位置的列表,以便将相等元素的位置组合在一起。矩阵m
的输出必须为:
{{1,1},{2,1}},{{2,2},{3,2}},{1,2},{1,3},{2,3},{3,1},{3,3}
% 1 2 3 4 5 6 7
我们在这里可以看到,彼此相等的元素的位置被组合在一起。
答案 0 :(得分:3)
最简单的方法是遍历每个唯一值并确定与每个值匹配的行和列位置。这样的事情可以奏效:
val = unique(m);
pos = cell(1, numel(val));
for ii = 1 : numel(val)
[r,c] = find(m == val(ii));
pos{ii} = [r,c];
end
pos
将是一个包含每个唯一值的所有位置的单元格数组。我们可以通过以下方式展示这些职位:
>> format compact; celldisp(pos)
pos{1} =
1 1
2 1
pos{2} =
1 2
pos{3} =
1 3
pos{4} =
2 2
3 2
pos{5} =
2 3
pos{6} =
3 1
pos{7} =
3 3
除非您专门显示每组职位的每个唯一值,否则这当然没有意义。因此,我们可以尝试这样的东西,而不是循环遍历单元格数组中的每个元素,以及显示每组位置所属的相应元素:
for ii = 1 : numel(val)
fprintf('Value: %f\n', val(ii));
fprintf('Positions:\n');
disp(pos{ii});
end
我现在得到的是:
Value: 1.000000
Positions:
1 1
2 1
Value: 2.000000
Positions:
1 2
Value: 3.000000
Positions:
1 3
Value: 4.000000
Positions:
2 2
3 2
Value: 5.000000
Positions:
2 3
Value: 6.000000
Positions:
3 1
Value: 7.000000
Positions:
3 3
答案 1 :(得分:1)
这给你你想要的东西,除了独特元素的索引也被包裹在单元格中两次,就像重复元素的索引一样:
m = [1,2,3;1,4,5;6,4,7];
[~, idx] = ismember(m(:), unique(m(:)));
linInd = 1:numel(m);
[i,j] = ind2sub(size(m), linInd);
res = accumarray(idx, linInd, [], @(x) {num2cell([i(x);j(x)]',2)});
结果:
>> celldisp(res)
res{1}{1} =
2 1
res{1}{2} =
1 1
res{2}{1} =
1 2
res{3}{1} =
1 3
res{4}{1} =
2 2
res{4}{2} =
3 2
res{5}{1} =
2 3
res{6}{1} =
3 1
res{7}{1} =
3 3