matlab - 如何生成所有可能的组合 n 位字符串?

标签 matlab bit-manipulation

给定一个正整数 n,我想在 matlab 中生成所有可能的 n 位组合。
例如:如果 n=3,那么答案应该是

000
001
010
011
100
101
110
111

我该怎么做? 我想实际将它们存储在矩阵中。我试过了

for n=1:2^4 
r(n)=dec2bin(n,5); 
end; 

但这给出了错误“在赋值 A(:) = B 中,A 和 B 中的元素数量必须相同。

最佳答案

只需遍历 [0,2^n) 中的所有整数,然后将数字打印为二进制。如果你总是想要 n 数字(例如插入前导零),这看起来像:

for ii=0:2^n-1,
    fprintf('%0*s\n', n, dec2bin(ii));
end

编辑:有多种方法可以将结果放入矩阵中。最简单的就是使用

x = dec2bin(0:2^n-1);

这将产生 n-by-2^n 类型的 char 矩阵。每行是一个位串。

如果你真的想在每一行中存储字符串,你可以这样做:

x = cell(1, 2^n);
for ii=0:2^n-1,
    x{ii} = dec2bin(ii);
end

但是,如果您正在寻找高效的处理,您应该记住整数已经以二进制形式存储在内存中!所以,向量:

x = 0 : 2^n-1;

以内存效率和 CPU 效率最高的方式包含二进制模式。唯一的权衡是您将无法使用这种紧凑表示法来表示 64 位中超过 32 位的模式。

关于matlab - 如何生成所有可能的组合 n 位字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9767321/

相关文章:

matlab - Matlab:使用“ismember”的代码性能问题

matlab - 在matlab中截断十进制数?

bit-manipulation - 除了快速数学运算之外,是否有充分的理由使用移位?

assembly - `test` 指令是如何工作的?

android - 试图理解 Bitmap.Config.ARBG_8888

c - IEEE 754 位操作舍入误差

python - 高效地在 Python 列表中查找索引(与 MATLAB 相比)

python - SVD 与 matlab、numpy 和 pytorch

matlab - 在 Matlab 中,如何按元素比较两个 container.Map 对象?

java - Java 中的位旋转 - 幂集,按大小排序