How do I create a 2^n by n matrix that the rows of the matrix enumerate all the possibilities for a n digit binary number?
2 次查看(过去 30 天)
显示 更早的评论
For example, for n=3, there are 8 rows, and they are 000,100,010,001,110,101,001,111 (may not in this order). Any fast way to realize it using a function, say f(n)?
0 个评论
采纳的回答
Guillaume
2016-2-11
Use dec2bin to get the string representation. Subtract '0' from the string to convert characters '0' and '1' to numbers 0 and 1:
n = 3;
dec2bin(0:pow2(n)-1) - '0'
2 个评论
Guillaume
2016-2-11
编辑:Guillaume
2016-2-11
In matlab, when you subtract one character from another, you are in effect subtracting the ASCII values of the character. So, obviously ASCII of '0' - ASCII of '0' is 0. Since '1' follows '0' in the ASCII table. ASCII of '1' - ASCII of '0' is 1. In fact, ASCII of any 'digit' - ASCII of '0' is that digit.
dec2bin will always return strings padded to the minimum number of bits to represent the greatest input. Since you need 3 bits to represent the 4 to 7 of the input array, all strings are returned with 3 bits.
You could have specified the number of bits explicitly if you wanted.
更多回答(1 个)
Jan
2016-2-11
r = VChooseKRO(uint8(0:1), 3);
2 个评论
Guillaume
2016-2-11
You'll have to compile the c code into a mex file. If you don't care for speed (if your n is not huge, speed is not an issue) you may be better off with some of the file exchange submission mentioned by VChooseKRO, or use my solution which has no dependency.
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Characters and Strings 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!