题目描述

  原理: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 }

版权声明:本文为maxin原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/maxin/p/5995755.html