how to build all binary vectors of length n whose number of its zero elements is m<n?

2 views (last 30 days)
how to build all binary vectors of length n whose number of its zero elements is m<n?

Answers (2)

Image Analyst
Image Analyst on 29 Jun 2013
If you specify m, and want all binary vectors with length longer than m, then there is an infinite number of vectors satisfying that. For example
m = 4;
output = false(1, 7) % This one has length 7.
output = false(1, 42) % This one has length 42.

Roger Stafford
Roger Stafford on 29 Jun 2013
Edited: Roger Stafford on 29 Jun 2013
N = 0;
for k = 0:m
N = N + nchoosek(n,k);
end
A = ones(N,n);
q = 1;
for k = 1:m
p = nchoosek(1:n,k);
for r = 1:size(p,1)
q = q+1;
A(q,p(r,:)) = 0;
end
end
The n-element rows of array A have all possible combinations of ones and zeros in which there are no more than m zeros. I assumed here that m and n were fixed quantities which you specify.

Categories

Find more on Random Number Generation in Help Center and File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!