c语言之将输入的十进制转换成二进制数并打印原码反码补码
2024-01-01 21:33:26
十进制转二进制
首先,我们要知道的是十进制转换成二进制数的方法。我们一般采用的除二取余的方法,在这里我用32位数组来进行转换。
int main()
{
printf("请输入一个十进制数\n");
int n = 0;
scanf("%d", &n);
int arr[32];
int* p = arr;
for (int i = 31; i >= 0; i--)
{
*(p + i) = n % 2;
n /= 2;
}
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
return 0;
}
以上是转换成二进制数并打印出来。
原码
原码第一位是符号位,正数为0,负数为1,其他不变。
int main()
{
printf("请输入一个十进制数\n");
int n = 0;
scanf("%d", &n);
int arr[32];
int* p = arr;
int k = n;
if (n < 0)
{
*p = 1;
k = -n;
}
else if (n > 0)
*p = 0;
for (int i = 31; i > 0; i--)
{
*(p + i) = k % 2;
k /= 2;
}
printf("原码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
return 0;
}
?
反码
若为正数,反码与原码相同。若为负数,反码在原码的基础上符号位不变,其他位按位取反
if (n < 0)
{
for (int i = 31; i > 0; i--)
{
if (*(p + i) == 1)
*(p + i) = 0;
else if (*(p + i) == 0)
*(p + i) = 1;
}
}
printf("\n反码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
补码
若为正数,补码与原码相同,若为负数,补码在反码的基础上末位加一,注意进位的问题。
if (n < 0)
{
*(p + 31) = *(p + 31) + 1;
for (int i = 31; i > 0; i--)
{
if (*(p + i) == 2)
{
*(p + i) = 0;
*(p + i - 1) += 1;
}
}
}
printf("\n补码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
return 0;
}
?
注意的是,这里有进位的部分,然后因为如果是负数的话,按位取反在反码部分已经完成了,所以不用再进行一遍。
all
最终的代码就是如下:
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
int main()
{
printf("请输入一个十进制数\n");
int n = 0;
scanf("%d", &n);
int arr[32];
int* p = arr;
int k = n;
if (n < 0)
{
*p = 1;
k = -n;
}
else if (n > 0)
*p = 0;
for (int i = 31; i > 0; i--)
{
*(p + i) = k % 2;
k /= 2;
}
printf("原码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
if (n < 0)
{
for (int i = 31; i > 0; i--)
{
if (*(p + i) == 1)
*(p + i) = 0;
else if (*(p + i) == 0)
*(p + i) = 1;
}
}
printf("\n反码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
if (n < 0)
{
*(p + 31) = *(p + 31) + 1;
for (int i = 31; i > 0; i--)
{
if (*(p + i) == 2)
{
*(p + i) = 0;
*(p + i - 1) += 1;
}
}
}
printf("\n补码:\n");
for (int i = 0; i < 32; i++)
{
if (i % 8 == 0)
printf(" ");
printf("%d", *(p + i));
}
return 0;
}
?
?下面是我的两个运行。
?
?
?
祝:“码”,思泉涌,下“指”如有神。?
文章来源:https://blog.csdn.net/2301_79990723/article/details/135328009
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!