我有 2 个单元矩阵(来自某个代码):
m1 = GO:0008150' 'GO:0016740'
'GO:0016740' 'GO:0016787'
'GO:0016787' 'GO:0006810'
'GO:0008150' 'GO:0006412'
'GO:0016740' 'GO:0004672'
'GO:0016740' 'GO:0016779'
'GO:0016787' 'GO:0004386'
'GO:0016787' 'GO:0003774'
'GO:0016787' 'GO:0016298'
'GO:0006810' 'GO:0016192'
m2 ='GO:0008150' 'GO:0016787'
'GO:0008150' 'GO:0006810'
'GO:0006810' 'GO:0006412'
'GO:0016192' 'GO:0003774'
'GO:0006810' 'GO:0005215'
'GO:0005215' 'GO:0030533'
在每个矩阵中,第一列是第二列的父...我需要从代码中找到可以确定这些单元格之间所有关系的图形部分...我必须从第 1 列中找到出现在第 2 列,然后从第 1 列但从第 2 列的同一行中取出单元格,并找到它与第 2 列中的另一个单元格之间的相似性 .. 等等.. 这类似于图论中的深度优先搜索
一般来说,我如何制作可以替换以下 if 语句的大小灵活的代码(递归):
for k=1:length(m1)
for ii=1:length(m1)
for j=1:length(m1)
for i=1:length(m2)
for e=1:length(m1)
if isequal(m2{i,1},m1{j,2})
x1=[m1(j,1) m2(i,2)];
x11=[x1;x11];
if isequal(m1{j,1},m1{k,2})
x2=[m1(k,1),m2(i,2)];
x22=[x2;x22];
if isequal(m1{k,1},m1{ii,2})
x3=[m1(ii,1),m2(i,2)];
x33=[x3;x33];
if isequal(m1{ii,1},m1{e,2})
x4=[m1(e,1),m2(i,2)];
x44=[x4;x44];
.
.
and so..x_total=[x11;x22;x33;x44...]
end
end
end
end
end
end
end
请注意,if statemtnes 的数量不确定(它取决于 m1 和 m2,它们也不总是常量)