10进制转原码,反码,补码c++
时间: 2024-01-13 17:03:53 浏览: 143
10进制转原码、反码、补码的方法如下:
1. 原码:将10进制数的绝对值转换成二进制数,然后在最高位上加上符号位(0表示正数,1表示负数)即可得到原码。
2. 反码:正数的反码与原码相同,负数的反码是将其原码中除符号位以外的所有位取反。
3. 补码:正数的补码与原码相同,负数的补码是将其反码加1。
C++代码实现:
```c++
#include <iostream>
using namespace std;
// 将10进制数转换为二进制数
void decToBin(int n, int bin[]) {
int i = 0;
while (n > 0) {
bin[i++] = n % 2;
n /= 2;
}
}
// 将二进制数转换为10进制数
int binToDec(int bin[], int len) {
int dec = 0;
for (int i = len - 1; i >= 0; i--) {
dec += bin[i] * pow(2, len - i - 1);
}
return dec;
}
// 将原码转换为反码
void oriToRev(int ori[], int len) {
for (int i = 0; i < len; i++) {
if (ori[i] == 1) {
ori[i] = 0;
} else {
ori[i] = 1;
}
}
}
// 将反码转换为补码
void revToCom(int rev[], int len) {
int carry = 1;
for (int i = len - 1; i >= 0; i--) {
if (rev[i] == 1 && carry == 1) {
rev[i] = 0;
} else if (rev[i] == 0 && carry == 1) {
rev[i] = 1;
carry = 0;
}
}
}
int main() {
int n = -10; // 待转换的10进制数
int len = 32; // 二进制数的位数
int bin[len] = {0}; // 存放二进制数的数组
int ori[len] = {0}; // 存放原码的数组
int rev[len] = {0}; // 存放反码的数组
int com[len] = {0}; // 存放补码的数组
// 将10进制数转换为二进制数
decToBin(abs(n), bin);
// 将二进制数转换为原码
if (n >= 0) {
ori[0] = 0;
for (int i = 0; i < len - 1; i++) {
ori[i + 1] = bin[i];
}
} else {
ori[0] = 1;
for (int i = 0; i < len - 1; i++) {
ori[i + 1] = bin[i];
}
}
// 将原码转换为反码
if (n < 0) {
oriToRev(ori, len);
}
// 将反码转换为补码
if (n < 0) {
revToCom(ori, len);
}
// 输出结果
cout << "原码:";
for (int i = 0; i < len; i++) {
cout << ori[i];
}
cout << endl;
if (n < 0) {
cout << "反码:";
for (int i = 0; i < len; i++) {
cout << ori[i];
}
cout << endl;
cout << "补码:";
for (int i = 0; i < len; i++) {
cout << com[i];
}
cout << endl;
}
return 0;
}
```
阅读全文