我有以下代码:
a = cell(4,1);
a{1} = [5 3 0 0];
a{2} = [0 3 5 0];
a{3} = [1 3 0 0];
a{4} = [0 3 2 0];
arrayind = 2;
b = a(cellfun(@(x)x(arrayind) == 1,a));
b{:}
使用IF语句时如何实现此目的:
if r>2
b = a(cellfun(@(x)x(arrayind) == (1 | 2 | 3),a));
end
基本上说,找到1,如果没有那么2,如果不存在那么3 ......
答案 0 :(得分:0)
ismember
也许就是你想要的。
用ismember
替换等于运算符,如下所示:
a = cell(4,1);
a{1} = [5 3 0 0];
a{2} = [0 3 5 0];
a{3} = [1 3 0 0];
a{4} = [0 3 2 0];
arrayind = 1;
b = a(cellfun(@(x) ismember(x(arrayind), [1 5]), a));
会产生b = a([1, 3])