2

我有如下单元格数组:

S{1} = [10,20,30,40,50];
S{2} = [10,20,40,50];
S{3} = [10,50,510];
S{4} = [10,20,70,40,60];
S{5} = [20,40];

而且,我需要找到以下子项的单元格行:

[10,20,30,40,50,60]

对于上面的示例结果是:

1,2,5 

因为第 1 行和第 2 行以及第 5 行只有 [10,20,30,40,50,60] 的子项。

在我的工作中,单元格数组很大。我需要一个快速的代码。

4

1 回答 1

7

S{1} = [10,20,30,40,50];
S{2} = [10,20,40,50];
S{3} = [10,50,510];
S{4} = [10,20,70,40,60];
S{5} = [20,40];            % data
t = [10,20,30,40,50,60];   % target values

然后,您可以通过 将ismemberall应用于每个单元格的内容cellfun。结果是一个逻辑向量,您可以从中获得所需的索引find

result = find(cellfun(@(x) all(ismember(x, t)), S));

另一种选择(我不知道在您的情况下哪个会更快)是ismember通过计算所有成对比较bsxfun然后应用来替换any

result = find(cellfun(@(x) all(any(bsxfun(@eq, t(:), x(:).'), 1)), S));
于 2017-06-07T09:55:13.933 回答