十进制到二进制转换
我需要使用C编程将20位十进制转换为二进制。 我将创建什么缓冲区,因为它会非常大,即使计算器也无法计算将20位数转换为二进制数。
这是我打算完成的样本:
我假设这段代码:我通过键盘输入缓冲区。 同时,我使用的是AT85C55WD Mcu。
unsigned char idata token [20] =(2,3,5,6,3,3,4,4,3,2,4,4,6,7,4,3,4,5,3,3);
我想要一个结果
type-define variable convrt_token = 23562244324467434533;
这可能使用C吗? 如果是的话,那我该怎么办呢?
这是一个优雅的解决方案…. 🙂
#include #include #include #include #include #include #include #define max 10000 #define RLC(num,pos) ((num << pos)|(num >> (32 - pos))) #define RRC(num,pos) ((num >> pos)|(num << (32 - pos))) void tobinstr(int value, int bitsCount, char* output) { int i; output[bitsCount] = '\0'; for (i = bitsCount - 1; i >= 0; --i, value >>= 1) { output[i] = (value & 1) + '0'; } } int main() { char s[50]; tobinstr(65536,32, s); printf("%s\n", s); return 0; }
十进制中的每个数字都有10个值,0..9。 所以你需要二进制3到4位数。 所以让我们说4保持简单。
因此,对于20位十进制,您需要一个二进制的80位数字。
你可以用字符来完成所有这一切,以保持简单。 我认为这是为了好玩。
char decnum [20]; char binnum [80];
祝好运。
从Gidon提到开始。 然后你只需要定义一个函数’decToBin’或类似的东西,你可以像这样使用:
char decnum[20]; char binnum[80]; // ... get the values, do zero initialization etc... decToBin( decnum, binnum );
你准备好了。
decToBin函数可以很容易地实现为常见的长除法算法。 那应该不会太难。
玩得开心 ;)
编辑:详细说明:
-
看看你的最后一位数。 它被2整除吗?
– >是:您的二进制数字将为0
– >否:你的二进制数字为1 -
将整个十进制数除以2(优选长除)并在必要时截断 。
-
重来。 您将以相反的顺序获得二进制数字。 (重复直到您的十进制数为0)