7-36 IP地址转换
一个IP地址是用四个字节(每个字节8个位)的二进制码组成。请将32位二进制码表示的IP地址转换为十进制格式表示的IP地址输出。
输入格式:
输入在一行中给出32位二进制字符串。
输出格式:
在一行中输出十进制格式的IP地址,其由4个十进制数组成(分别对应4个8位的二进制数),中间用“.”分隔开。
输入样例:
11001100100101000001010101110010
输出样例:
204.148.21.114
虽然代码长了点但是感觉挺好理解的
#include<iostream>
#include<math.h>
using namespace std;
int main()
{
char arr[32];//一共32位
for (int i = 31; i>=0; i--)
scanf_s("%c", &arr[i]);//一个一个输入
int a = 0;
int sum = 0;
for (int i = 31; i >= 0; i--) //从后往前计算
{//11001100100101000001010101110010
switch (i % 8)
{
case 0: {//当i%8 ==0 的时候正好 输出一次
if (arr[i] != '0')
{
a = pow(2, i % 8);
}
else
a = 0;
//格式要求
if (i != 0)
{
sum += a;
cout << sum << ".";
sum = 0; a = 0;//记得sum 和 a要初始化为0
break;
}
else
{
sum += a;
a = 0;
cout << sum;
sum = 0;
break;
}
}
case 1:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 2:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 3:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 4:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 5:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 6:
{
if (arr[i] != '0')
{
a = pow(2, i % 8); break;
}
else
a = 0; break;
}
case 7: {
if (arr[i] != '0')
{
a = pow(2, i%8); break;
}
else
a = 0; break;
}
}
sum += a;
}
system("pause");
}