Рассмотрим это решение, используя функцию NDGRID :
sets = {[1 2], [1 2], [4 5]};
[x y z] = ndgrid(sets{:});
cartProd = [x(:) y(:) z(:)];
cartProd =
1 1 4
2 1 4
1 2 4
2 2 4
1 1 5
2 1 5
1 2 5
2 2 5
Или, если вы хотите общее решение для любого числа наборов (без необходимости создания переменных вручную), используйте это определение функции:
function result = cartesianProduct(sets)
c = cell(1, numel(sets));
[c{:}] = ndgrid( sets{:} );
result = cell2mat( cellfun(@(v)v(:), c, 'UniformOutput',false) );
end
Обратите внимание, что если вы предпочитаете, вы можете отсортировать результаты:
cartProd = sortrows(cartProd, 1:numel(sets));
Кроме того, приведенный выше код не проверяет, не имеют ли наборы повторяющихся значений (например: {[1 1] [1 2] [4 5]}
). Добавьте эту строку, если хотите:
sets = cellfun(@unique, sets, 'UniformOutput',false);