题目描述
原理:ip地址的每段可以看成是一个0-255的整数,把每段拆分成一个二进制形式组合起来,然后把这个二进制数转变成一个长整数。
举例:一个ip地址为10.0.3.193
每段数字 相对应的二进制数
10 00001010
0 00000000
3 00000011
193 11000001
组合起来即为:00001010 00000000 00000011 11000001,转换为10进制数就是:167773121,即该IP地址转换后的数字就是它了。
输入描述
输入
1 输入IP地址
2 输入10进制型的IP地址
输出描述
输出
1 输出转换成10进制的IP地址
2 输出转换后的IP地址
输入样例
10.0.3.193 167969729
输出样例
167773121 10.3.3.193
测试代码
1 #include <stdio.h> 2 3 int main(void) 4 { 5 int a, b, c, d; 6 char ch; 7 long long int n, res; 8 9 while(scanf("%d%c%d%c%d%c%d", &a, &ch, &b, &ch, &c, &ch, &d) == 7) 10 { 11 res = (a << 24) | (b << 16) | (c << 8) | d; 12 scanf("%lld", &n); 13 a = n >> 24; 14 b = (n >> 16) & 255; 15 c = (n >> 8) & 255; 16 d = n & 255; 17 printf("%lld\n%d.%d.%d.%d\n", res, a, b, c, d); 18 } 19 20 return 0; 21 }