IP地址转换(简单暴力)C/C++

【摘要】 题目描述 一个IP地址是用四个字节(每个字节8个位)的二进制码组成。请将32位二进制码表示的IP地址转换为十进制格式表示的IP地址输出。
输入 第一行输入一个n,表示有n个32位二进制的字符串 接下来n行中每行给出一个32位二进制字符串。
输出 每一行输出与其对应的十进制格式的IP地址,其由4个十进制数组成(分别对应4个8位的二进制数),中间用“.”分隔开。
样例…

题目描述
一个IP地址是用四个字节(每个字节8个位)的二进制码组成。请将32位二进制码表示的IP地址转换为十进制格式表示的IP地址输出。

输入
第一行输入一个n,表示有n个32位二进制的字符串
接下来n行中每行给出一个32位二进制字符串。

输出
每一行输出与其对应的十进制格式的IP地址,其由4个十进制数组成(分别对应4个8位的二进制数),中间用“.”分隔开。

样例输入
3
10101000110001011111001010111111
10011000001101111110101001111110
00110011101001010010111100110001
样例输出
168.197.242.191
152.55.234.126
51.165.47.49

下面为通过代码:

#include<iostream>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#include <algorithm>
#include<string.h>
#include<math.h>
#define llu unsigned long long
using namespace std;
int main()
{
	cout << fixed << setprecision(0);
	//cout << setw(8) << setiosflags(ios::left);
	int n,b[4];//每一个元素存8位二进制数转换后的十进制数
	char a[35];//用字符串存二进制数
	cin >> n;
	while( n>0 ){
		cin >> a ;
		b[0]=(a[0]-'0')*pow(2,7)+(a[1]-'0')*pow(2,6)+(a[2]-'0')*pow(2,5)+(a[3]-'0')*pow( 2,4 )+(a[4]-'0')*pow( 2,3 )+(a[5]-'0')*pow( 2,2 )+(a[6]-'0')*pow( 2,1 )+(a[7]-'0')*pow( 2,0 );
		b[1]=(a[8]-'0')*pow(2,7)+(a[9]-'0')*pow(2,6)+(a[10]-'0')*pow(2,5)+(a[11]-'0')*pow( 2,4 )+(a[12]-'0')*pow( 2,3 )+(a[13]-'0')*pow( 2,2 )+(a[14]-'0')*pow( 2,1 )+(a[15]-'0')*pow( 2,0 );
		b[2]=(a[16]-'0')*pow(2,7)+(a[17]-'0')*pow(2,6)+(a[18]-'0')*pow(2,5)+(a[19]-'0')*pow( 2,4 )+(a[20]-'0')*pow( 2,3 )+(a[21]-'0')*pow( 2,2 )+(a[22]-'0')*pow( 2,1 )+(a[23]-'0')*pow( 2,0 );
		b[3]=(a[24]-'0')*pow(2,7)+(a[25]-'0')*pow(2,6)+(a[26]-'0')*pow(2,5)+(a[27]-'0')*pow( 2,4 )+(a[28]-'0')*pow( 2,3 )+(a[29]-'0')*pow( 2,2 )+(a[30]-'0')*pow( 2,1 )+(a[31]-'0')*pow( 2,0 );
		n--;
		cout << b[0] << "." << b[1] << "." << b[2] << "." << b[3] << endl;
	} 
	return 0;
}
  
 

文章来源: blog.csdn.net,作者:深巷wls,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/wangyurenwls/article/details/116396421

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享